Skip to content

Commit

Permalink
Add missing fields to CreateFollowIndexRequest (#3042) (#3415)
Browse files Browse the repository at this point in the history
(cherry picked from commit d633341)

Co-authored-by: Florian Bernd <[email protected]>
  • Loading branch information
pquentin and flobernd authored Jan 2, 2025
1 parent 04f3f50 commit c34e26d
Show file tree
Hide file tree
Showing 2 changed files with 117 additions and 23 deletions.
81 changes: 70 additions & 11 deletions specification/ccr/follow/CreateFollowIndexRequest.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,10 @@
* under the License.
*/

import { IndexSettings } from '@indices/_types/IndexSettings'
import { RequestBase } from '@_types/Base'
import { IndexName, WaitForActiveShards } from '@_types/common'
import { long } from '@_types/Numeric'
import { ByteSize, IndexName, WaitForActiveShards } from '@_types/common'
import { integer, long } from '@_types/Numeric'
import { Duration } from '@_types/Time'

/**
Expand All @@ -32,23 +33,81 @@ import { Duration } from '@_types/Time'
*/
export interface Request extends RequestBase {
path_parts: {
/**
* The name of the follower index.
*/
index: IndexName
}
query_parameters: {
/**
* Specifies the number of shards to wait on being active before responding. This defaults to waiting on none of the shards to be
* active.
* A shard must be restored from the leader index before being active. Restoring a follower shard requires transferring all the
* remote Lucene segment files to the follower index.
*/
wait_for_active_shards?: WaitForActiveShards
}
body: {
leader_index?: IndexName
/**
* If the leader index is part of a data stream, the name to which the local data stream for the followed index should be renamed.
*/
data_stream_name?: string
/**
* The name of the index in the leader cluster to follow.
*/
leader_index: IndexName
/**
* The maximum number of outstanding reads requests from the remote cluster.
*/
max_outstanding_read_requests?: long
max_outstanding_write_requests?: long
max_read_request_operation_count?: long
max_read_request_size?: string
/**
* The maximum number of outstanding write requests on the follower.
*/
max_outstanding_write_requests?: integer
/**
* The maximum number of operations to pull per read from the remote cluster.
*/
max_read_request_operation_count?: integer
/**
* The maximum size in bytes of per read of a batch of operations pulled from the remote cluster.
*/
max_read_request_size?: ByteSize
/**
* The maximum time to wait before retrying an operation that failed exceptionally. An exponential backoff strategy is employed when
* retrying.
*/
max_retry_delay?: Duration
max_write_buffer_count?: long
max_write_buffer_size?: string
max_write_request_operation_count?: long
max_write_request_size?: string
/**
* The maximum number of operations that can be queued for writing. When this limit is reached, reads from the remote cluster will be
* deferred until the number of queued operations goes below the limit.
*/
max_write_buffer_count?: integer
/**
* The maximum total bytes of operations that can be queued for writing. When this limit is reached, reads from the remote cluster will
* be deferred until the total bytes of queued operations goes below the limit.
*/
max_write_buffer_size?: ByteSize
/**
* The maximum number of operations per bulk write request executed on the follower.
*/
max_write_request_operation_count?: integer
/**
* The maximum total bytes of operations per bulk write request executed on the follower.
*/
max_write_request_size?: ByteSize
/**
* The maximum time to wait for new operations on the remote cluster when the follower index is synchronized with the leader index.
* When the timeout has elapsed, the poll for operations will return to the follower so that it can update some statistics.
* Then the follower will immediately attempt to read from the leader again.
*/
read_poll_timeout?: Duration
remote_cluster?: string
/**
* The remote cluster containing the leader index.
*/
remote_cluster: string
/**
* Settings to override from the leader index.
*/
settings?: IndexSettings
}
}
59 changes: 47 additions & 12 deletions specification/ccr/follow_info/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,8 @@
* under the License.
*/

import { IndexName, Name } from '@_types/common'
import { integer } from '@_types/Numeric'
import { ByteSize, IndexName, Name } from '@_types/common'
import { integer, long } from '@_types/Numeric'
import { Duration } from '@_types/Time'

export class FollowerIndex {
Expand All @@ -35,14 +35,49 @@ export enum FollowerIndexStatus {
}

export class FollowerIndexParameters {
max_outstanding_read_requests: integer
max_outstanding_write_requests: integer
max_read_request_operation_count: integer
max_read_request_size: string
max_retry_delay: Duration
max_write_buffer_count: integer
max_write_buffer_size: string
max_write_request_operation_count: integer
max_write_request_size: string
read_poll_timeout: Duration
/**
* The maximum number of outstanding reads requests from the remote cluster.
*/
max_outstanding_read_requests?: long
/**
* The maximum number of outstanding write requests on the follower.
*/
max_outstanding_write_requests?: integer
/**
* The maximum number of operations to pull per read from the remote cluster.
*/
max_read_request_operation_count?: integer
/**
* The maximum size in bytes of per read of a batch of operations pulled from the remote cluster.
*/
max_read_request_size?: ByteSize
/**
* The maximum time to wait before retrying an operation that failed exceptionally. An exponential backoff strategy is employed when
* retrying.
*/
max_retry_delay?: Duration
/**
* The maximum number of operations that can be queued for writing. When this limit is reached, reads from the remote cluster will be
* deferred until the number of queued operations goes below the limit.
*/
max_write_buffer_count?: integer
/**
* The maximum total bytes of operations that can be queued for writing. When this limit is reached, reads from the remote cluster will
* be deferred until the total bytes of queued operations goes below the limit.
*/
max_write_buffer_size?: ByteSize
/**
* The maximum number of operations per bulk write request executed on the follower.
*/
max_write_request_operation_count?: integer
/**
* The maximum total bytes of operations per bulk write request executed on the follower.
*/
max_write_request_size?: ByteSize
/**
* The maximum time to wait for new operations on the remote cluster when the follower index is synchronized with the leader index.
* When the timeout has elapsed, the poll for operations will return to the follower so that it can update some statistics.
* Then the follower will immediately attempt to read from the leader again.
*/
read_poll_timeout?: Duration
}

0 comments on commit c34e26d

Please sign in to comment.