From 8471d24113b8e979b88c7cf9b91eb686e5892b4a Mon Sep 17 00:00:00 2001 From: Bhumika Saini Date: Fri, 8 Sep 2023 15:41:02 +0530 Subject: [PATCH 1/7] Update docs for remote_store.moving_average_window_size Signed-off-by: Bhumika Saini --- _api-reference/cluster-api/cluster-settings.md | 1 + .../remote-store/remote-segment-backpressure.md | 8 +++----- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/_api-reference/cluster-api/cluster-settings.md b/_api-reference/cluster-api/cluster-settings.md index 4a8639cbc0..49c7475ecf 100644 --- a/_api-reference/cluster-api/cluster-settings.md +++ b/_api-reference/cluster-api/cluster-settings.md @@ -107,6 +107,7 @@ The following request field parameters are compatible with the cluster API. | cluster.max_shards_per_node | Integer | Limits the total number of primary and replica shards for the cluster. The limit is calculated as follows: `cluster.max_shards_per_node` multiplied by the number of non-frozen data nodes. Shards for closed indexes do not count toward this limit. Default is `1000`. | | cluster.persistent_tasks.allocation.enable | String | Enables or disables allocation for persistent tasks:

`all` – Allows persistent tasks to be assigned to nodes.

`none` – No allocations are allowed for persistent tasks. This does not affect persistent tasks already running.

Default is `all`. | | cluster.persistent_tasks.allocation.recheck_interval | Time unit | The cluster manager automatically checks whether or not persistent tasks need to be assigned when the cluster state changes in a significant way. There are other factors, such as memory usage, that will affect whether or not persistent tasks are assigned to nodes but do not otherwise cause the cluster state to change. This setting defines how often assignment checks are performed in response to these factors. Default is `30 seconds`, with a minimum of `10 seconds` being required. | +| remote_store.moving_average_window_size | Integer | The moving average window size used to calculate the rolling statistic values exposed through [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. | #### Example request diff --git a/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md b/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md index 4fa427509a..707bb6ee29 100644 --- a/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md +++ b/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md @@ -18,8 +18,8 @@ Remote segment backpressure is a shard-level rejection mechanism that dynamicall Remote segment backpressure is activated if any of the following thresholds is breached: - **Consecutive failure**: The backpressure is activated if there are _N_ or more consecutive failures. The value of _N_ is configurable in `remote_store.segment.pressure.consecutive_failures.limit`. -- **Bytes lag**: The bytes lag is computed by adding the size of all files that are present in local committed segments but not in the remote store. The backpressure is activated if the bytes lag is greater than _K_ multiplied by the moving average of the size (in bytes) of files uploaded after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.bytes_lag.variance_factor`. The moving window size is configurable in `remote_store.segment.pressure.upload_bytes_moving_average_window_size`. -- **Time lag**: The time lag is computed by comparing the timestamps of the most recent local refresh and the most recent remote store segment upload. The backpressure is activated if the time lag is greater than _K_ multiplied by the moving average of the time taken to upload new segments and metadata file after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.time_lag.variance_factor`. The moving window size is configurable in `remote_store.segment.pressure.upload_time_moving_average_window_size`. +- **Bytes lag**: The bytes lag is computed by adding the size of all files that are present in local committed segments but not in the remote store. The backpressure is activated if the bytes lag is greater than _K_ multiplied by the moving average of the size (in bytes) of files uploaded after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.bytes_lag.variance_factor`. The moving window size is configurable in `remote_store.moving_average_window_size`. +- **Time lag**: The time lag is computed by comparing the timestamps of the most recent local refresh and the most recent remote store segment upload. The backpressure is activated if the time lag is greater than _K_ multiplied by the moving average of the time taken to upload new segments and metadata file after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.time_lag.variance_factor`. The moving window size is configurable in `remote_store.moving_average_window_size`. ## Handling segment merges @@ -36,13 +36,11 @@ The following table lists the settings used for activating backpressure. For thr |`remote_store.segment.pressure.enabled` |Boolean | If `true`, enables remote segment backpressure. Default is `false`. | |`remote_store.segment.pressure.consecutive_failures.limit` |Integer |The minimum consecutive failure count for activating remote segment backpressure. Default is `5`. | |`remote_store.segment.pressure.bytes_lag.variance_factor` |Float | The variance factor that is used together with the moving average to calculate the dynamic bytes lag threshold for activating remote segment backpressure. Default is `10`. | -|`remote_store.segment.pressure.upload_bytes_moving_average_window_size` |Integer |The moving average window size that is used to calculate the dynamic bytes lag threshold for activating remote segment backpressure. The moving average is also exposed through the [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. | |`remote_store.segment.pressure.time_lag.variance_factor` |Float |The variance factor that is used together with the moving average to calculate the dynamic time lag threshold for activating remote segment backpressure. Default is `10`. | -|`remote_store.segment.pressure.upload_time_moving_average_window_size` |Integer |The moving average window size that is used to calculate the dynamic time lag threshold for activating remote segment backpressure. The moving average is also exposed through the [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`.| The following table lists the settings used for statistics. |Setting |Data type |Description | |:--- |:--- |:--- | -|`remote_store.segment.pressure.upload_bytes_per_sec_moving_average_window_size` |Integer |The moving average window size, which is exposed through [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`.| +|`remote_store.moving_average_window_size` |Integer | The moving average window size used to calculate the rolling statistic values exposed through [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. | From afad4e0043a0d1fbcf12902b4755a3a1a79bad5a Mon Sep 17 00:00:00 2001 From: Bhumika Saini Date: Fri, 8 Sep 2023 17:19:26 +0530 Subject: [PATCH 2/7] Update docs for Remote Segment and Remote Translog store stats surfaced via nodes/indices/cluster stats APIs Signed-off-by: Bhumika Saini --- _api-reference/cluster-api/cluster-stats.md | 23 +++ _api-reference/index-apis/stats.md | 156 +++++++++++++++++++- _api-reference/nodes-apis/nodes-stats.md | 66 ++++++++- 3 files changed, 240 insertions(+), 5 deletions(-) diff --git a/_api-reference/cluster-api/cluster-stats.md b/_api-reference/cluster-api/cluster-stats.md index b717199c24..8d69cf21f6 100644 --- a/_api-reference/cluster-api/cluster-stats.md +++ b/_api-reference/cluster-api/cluster-stats.md @@ -116,6 +116,29 @@ Parameter | Type | Description "version_map_memory_in_bytes": 0, "fixed_bit_set_memory_in_bytes": 1112, "max_unsafe_auto_id_timestamp": 1644269449096, + "remote_store" : { + "upload" : { + "total_upload_size" : { + "started_bytes" : 152419, + "succeeded_bytes" : 152419, + "failed_bytes" : 0 + }, + "refresh_size_lag" : { + "total_bytes" : 0, + "max_bytes" : 0 + }, + "max_refresh_time_lag_in_millis" : 0, + "total_time_spent_in_millis" : 516 + }, + "download" : { + "total_download_size" : { + "started_bytes" : 0, + "succeeded_bytes" : 0, + "failed_bytes" : 0 + }, + "total_time_spent_in_millis" : 0 + } + }, "file_sizes": {} }, "mappings": { diff --git a/_api-reference/index-apis/stats.md b/_api-reference/index-apis/stats.md index de887a47d6..4bd1b2f80e 100644 --- a/_api-reference/index-apis/stats.md +++ b/_api-reference/index-apis/stats.md @@ -199,6 +199,29 @@ By default, the returned statistics are aggregated in the `primaries` and `total "version_map_memory_in_bytes": 0, "fixed_bit_set_memory_in_bytes": 0, "max_unsafe_auto_id_timestamp": -1, + "remote_store" : { + "upload" : { + "total_upload_size" : { + "started_bytes" : 152419, + "succeeded_bytes" : 152419, + "failed_bytes" : 0 + }, + "refresh_size_lag" : { + "total_bytes" : 0, + "max_bytes" : 0 + }, + "max_refresh_time_lag_in_millis" : 0, + "total_time_spent_in_millis" : 516 + }, + "download" : { + "total_download_size" : { + "started_bytes" : 0, + "succeeded_bytes" : 0, + "failed_bytes" : 0 + }, + "total_time_spent_in_millis" : 0 + } + }, "file_sizes": {} }, "translog": { @@ -206,7 +229,21 @@ By default, the returned statistics are aggregated in the `primaries` and `total "size_in_bytes": 55, "uncommitted_operations": 0, "uncommitted_size_in_bytes": 55, - "earliest_last_modified_age": 142622215 + "earliest_last_modified_age": 142622215, + "remote_store" : { + "upload" : { + "total_uploads" : { + "started" : 57, + "failed" : 0, + "succeeded" : 57 + }, + "total_upload_size" : { + "started_bytes" : 16830, + "failed_bytes" : 0, + "succeeded_bytes" : 16830 + } + } + } }, "request_cache": { "memory_size_in_bytes": 0, @@ -326,6 +363,29 @@ By default, the returned statistics are aggregated in the `primaries` and `total "version_map_memory_in_bytes": 0, "fixed_bit_set_memory_in_bytes": 0, "max_unsafe_auto_id_timestamp": -1, + "remote_store" : { + "upload" : { + "total_upload_size" : { + "started_bytes" : 152419, + "succeeded_bytes" : 152419, + "failed_bytes" : 0 + }, + "refresh_size_lag" : { + "total_bytes" : 0, + "max_bytes" : 0 + }, + "max_refresh_time_lag_in_millis" : 0, + "total_time_spent_in_millis" : 516 + }, + "download" : { + "total_download_size" : { + "started_bytes" : 0, + "succeeded_bytes" : 0, + "failed_bytes" : 0 + }, + "total_time_spent_in_millis" : 0 + } + }, "file_sizes": {} }, "translog": { @@ -333,7 +393,21 @@ By default, the returned statistics are aggregated in the `primaries` and `total "size_in_bytes": 55, "uncommitted_operations": 0, "uncommitted_size_in_bytes": 55, - "earliest_last_modified_age": 142622215 + "earliest_last_modified_age": 142622215, + "remote_store" : { + "upload" : { + "total_uploads" : { + "started" : 57, + "failed" : 0, + "succeeded" : 57 + }, + "total_upload_size" : { + "started_bytes" : 16830, + "failed_bytes" : 0, + "succeeded_bytes" : 16830 + } + } + } }, "request_cache": { "memory_size_in_bytes": 0, @@ -457,6 +531,29 @@ By default, the returned statistics are aggregated in the `primaries` and `total "version_map_memory_in_bytes": 0, "fixed_bit_set_memory_in_bytes": 0, "max_unsafe_auto_id_timestamp": -1, + "remote_store" : { + "upload" : { + "total_upload_size" : { + "started_bytes" : 152419, + "succeeded_bytes" : 152419, + "failed_bytes" : 0 + }, + "refresh_size_lag" : { + "total_bytes" : 0, + "max_bytes" : 0 + }, + "max_refresh_time_lag_in_millis" : 0, + "total_time_spent_in_millis" : 516 + }, + "download" : { + "total_download_size" : { + "started_bytes" : 0, + "succeeded_bytes" : 0, + "failed_bytes" : 0 + }, + "total_time_spent_in_millis" : 0 + } + }, "file_sizes": {} }, "translog": { @@ -464,7 +561,21 @@ By default, the returned statistics are aggregated in the `primaries` and `total "size_in_bytes": 55, "uncommitted_operations": 0, "uncommitted_size_in_bytes": 55, - "earliest_last_modified_age": 142622215 + "earliest_last_modified_age": 142622215, + "remote_store" : { + "upload" : { + "total_uploads" : { + "started" : 57, + "failed" : 0, + "succeeded" : 57 + }, + "total_upload_size" : { + "started_bytes" : 16830, + "failed_bytes" : 0, + "succeeded_bytes" : 16830 + } + } + } }, "request_cache": { "memory_size_in_bytes": 0, @@ -584,6 +695,29 @@ By default, the returned statistics are aggregated in the `primaries` and `total "version_map_memory_in_bytes": 0, "fixed_bit_set_memory_in_bytes": 0, "max_unsafe_auto_id_timestamp": -1, + "remote_store" : { + "upload" : { + "total_upload_size" : { + "started_bytes" : 152419, + "succeeded_bytes" : 152419, + "failed_bytes" : 0 + }, + "refresh_size_lag" : { + "total_bytes" : 0, + "max_bytes" : 0 + }, + "max_refresh_time_lag_in_millis" : 0, + "total_time_spent_in_millis" : 516 + }, + "download" : { + "total_download_size" : { + "started_bytes" : 0, + "succeeded_bytes" : 0, + "failed_bytes" : 0 + }, + "total_time_spent_in_millis" : 0 + } + }, "file_sizes": {} }, "translog": { @@ -591,7 +725,21 @@ By default, the returned statistics are aggregated in the `primaries` and `total "size_in_bytes": 55, "uncommitted_operations": 0, "uncommitted_size_in_bytes": 55, - "earliest_last_modified_age": 142622215 + "earliest_last_modified_age": 142622215, + "remote_store" : { + "upload" : { + "total_uploads" : { + "started" : 57, + "failed" : 0, + "succeeded" : 57 + }, + "total_upload_size" : { + "started_bytes" : 16830, + "failed_bytes" : 0, + "succeeded_bytes" : 16830 + } + } + } }, "request_cache": { "memory_size_in_bytes": 0, diff --git a/_api-reference/nodes-apis/nodes-stats.md b/_api-reference/nodes-apis/nodes-stats.md index 77e5f0d095..a9a4034ffa 100644 --- a/_api-reference/nodes-apis/nodes-stats.md +++ b/_api-reference/nodes-apis/nodes-stats.md @@ -245,6 +245,29 @@ Select the arrow to view the example response. "version_map_memory_in_bytes" : 0, "fixed_bit_set_memory_in_bytes" : 288, "max_unsafe_auto_id_timestamp" : -1, + "remote_store" : { + "upload" : { + "total_upload_size" : { + "started_bytes" : 152419, + "succeeded_bytes" : 152419, + "failed_bytes" : 0 + }, + "refresh_size_lag" : { + "total_bytes" : 0, + "max_bytes" : 0 + }, + "max_refresh_time_lag_in_millis" : 0, + "total_time_spent_in_millis" : 516 + }, + "download" : { + "total_download_size" : { + "started_bytes" : 0, + "succeeded_bytes" : 0, + "failed_bytes" : 0 + }, + "total_time_spent_in_millis" : 0 + } + }, "file_sizes" : { } }, "translog" : { @@ -252,7 +275,21 @@ Select the arrow to view the example response. "size_in_bytes" : 1452, "uncommitted_operations" : 12, "uncommitted_size_in_bytes" : 1452, - "earliest_last_modified_age" : 164160 + "earliest_last_modified_age" : 164160, + "remote_store" : { + "upload" : { + "total_uploads" : { + "started" : 57, + "failed" : 0, + "succeeded" : 57 + }, + "total_upload_size" : { + "started_bytes" : 16830, + "failed_bytes" : 0, + "succeeded_bytes" : 16830 + } + } + } }, "request_cache" : { "memory_size_in_bytes" : 1649, @@ -792,6 +829,23 @@ segments.index_writer_memory_in_bytes | Integer | The total amount of memory use segments.version_map_memory_in_bytes | Integer | The total amount of memory used by all version maps, in bytes. segments.fixed_bit_set_memory_in_bytes | Integer | The total amount of memory used by fixed bit sets, in bytes. Fixed bit sets are used for nested objects and join fields. segments.max_unsafe_auto_id_timestamp | Integer | The timestamp for the most recently retired indexing request, in milliseconds since the epoch. +segments.remote_store | Object | Statistics about Remote Segment Store operations. +segments.remote_store.upload | Object | Statistics about Remote Segment Store upload operations. +segments.remote_store.upload.total_upload_size | Object | The amount of data uploaded to Remote Segment Store. +segments.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes for which upload to Remote Segment Store has been started. +segments.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes for which upload to Remote Segment Store has succeeded. +segments.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes for which upload to Remote Segment Store has failed. +segments.remote_store.upload.refresh_size_lag | Object | Statistics about the bytes lag between the Remote Segment Store and local store. +segments.remote_store.upload.refresh_size_lag.total_bytes | Integer | The total bytes lag between the Remote Segment Store and local store. +segments.remote_store.upload.refresh_size_lag.max_bytes | Integer | The maximum bytes lag between the Remote Segment Store and local store. +segments.remote_store.upload.max_refresh_time_lag_in_millis | Integer | The max time duration (in milliseconds) the remote refresh is behind the local refresh. +segments.remote_store.upload.total_time_spent_in_millis | Integer | The total time duration (in milliseconds) spent on uploads to the Remote Segment Store. +segments.remote_store.download | Object | Statistics about Remote Segment Store download operations. +segments.remote_store.download.total_download_size | Object | The amount of data downloaded from Remote Segment Store. +segments.remote_store.download.total_download_size.started_bytes | Integer | The number of bytes for which download from Remote Segment Store has been started. +segments.remote_store.download.total_download_size.succeeded_bytes | Integer | The number of bytes for which download from Remote Segment Store has succeeded. +segments.remote_store.download.total_download_size.failed_bytes | Integer | The number of bytes for which download from Remote Segment Store has failed. +segments.remote_store.download.total_time_spent_in_millis | Integer | The total time duration (in milliseconds) spent on downloads from the Remote Segment Store. segments.file_sizes | Integer | Statistics about the size of the segment files. translog | Object | Statistics about transaction log operations for the node. translog.operations | Integer | The number of translog operations. @@ -799,6 +853,16 @@ translog.size_in_bytes | Integer | The size of the translog, in bytes. translog.uncommitted_operations | Integer | The number of uncommitted translog operations. translog.uncommitted_size_in_bytes | Integer | The size of uncommitted translog operations, in bytes. translog.earliest_last_modified_age | Integer | The earliest last modified age for the translog. +translog.remote_store | Object | Statistics about Remote Translog Store operations. +translog.remote_store.upload | Object | Statistics about Remote Translog Store upload operations. +translog.remote_store.upload.total_uploads | Object | The number of syncs to Remote Translog Store. +translog.remote_store.upload.total_uploads.started | Integer | The number of syncs to Remote Translog Store that have been started. +translog.remote_store.upload.total_uploads.failed | Integer | The number of syncs to Remote Translog Store that have failed. +translog.remote_store.upload.total_uploads.succeeded | Integer | The number of syncs to Remote Translog Store that have succeeded. +translog.remote_store.upload.total_upload_size | Object | The amount of data uploaded to Remote Translog Store. +translog.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes for which upload to Remote Translog Store has been started. +translog.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes for which upload to Remote Translog Store has failed. +translog.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes for which upload to Remote Translog Store has succeeded. request_cache | Object | Statistics about the request cache for the node. request_cache.memory_size_in_bytes | Integer | The memory size used by the request cache, in bytes. request_cache.evictions | Integer | The number of request cache evictions. From 3fb096d6c2976062b0c781dfa910ee296b9a4270 Mon Sep 17 00:00:00 2001 From: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> Date: Wed, 13 Sep 2023 11:04:33 -0500 Subject: [PATCH 3/7] Apply suggestions from code review Signed-off-by: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> --- _api-reference/nodes-apis/nodes-stats.md | 52 +++++++++---------- .../remote-segment-backpressure.md | 6 +-- 2 files changed, 29 insertions(+), 29 deletions(-) diff --git a/_api-reference/nodes-apis/nodes-stats.md b/_api-reference/nodes-apis/nodes-stats.md index a9a4034ffa..3361a7148c 100644 --- a/_api-reference/nodes-apis/nodes-stats.md +++ b/_api-reference/nodes-apis/nodes-stats.md @@ -829,23 +829,23 @@ segments.index_writer_memory_in_bytes | Integer | The total amount of memory use segments.version_map_memory_in_bytes | Integer | The total amount of memory used by all version maps, in bytes. segments.fixed_bit_set_memory_in_bytes | Integer | The total amount of memory used by fixed bit sets, in bytes. Fixed bit sets are used for nested objects and join fields. segments.max_unsafe_auto_id_timestamp | Integer | The timestamp for the most recently retired indexing request, in milliseconds since the epoch. -segments.remote_store | Object | Statistics about Remote Segment Store operations. +segments.remote_store | Object | Statistics about remote segment store operations. segments.remote_store.upload | Object | Statistics about Remote Segment Store upload operations. -segments.remote_store.upload.total_upload_size | Object | The amount of data uploaded to Remote Segment Store. -segments.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes for which upload to Remote Segment Store has been started. -segments.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes for which upload to Remote Segment Store has succeeded. -segments.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes for which upload to Remote Segment Store has failed. -segments.remote_store.upload.refresh_size_lag | Object | Statistics about the bytes lag between the Remote Segment Store and local store. -segments.remote_store.upload.refresh_size_lag.total_bytes | Integer | The total bytes lag between the Remote Segment Store and local store. -segments.remote_store.upload.refresh_size_lag.max_bytes | Integer | The maximum bytes lag between the Remote Segment Store and local store. -segments.remote_store.upload.max_refresh_time_lag_in_millis | Integer | The max time duration (in milliseconds) the remote refresh is behind the local refresh. -segments.remote_store.upload.total_time_spent_in_millis | Integer | The total time duration (in milliseconds) spent on uploads to the Remote Segment Store. -segments.remote_store.download | Object | Statistics about Remote Segment Store download operations. -segments.remote_store.download.total_download_size | Object | The amount of data downloaded from Remote Segment Store. -segments.remote_store.download.total_download_size.started_bytes | Integer | The number of bytes for which download from Remote Segment Store has been started. -segments.remote_store.download.total_download_size.succeeded_bytes | Integer | The number of bytes for which download from Remote Segment Store has succeeded. -segments.remote_store.download.total_download_size.failed_bytes | Integer | The number of bytes for which download from Remote Segment Store has failed. -segments.remote_store.download.total_time_spent_in_millis | Integer | The total time duration (in milliseconds) spent on downloads from the Remote Segment Store. +segments.remote_store.upload.total_upload_size | Object | The amount of data in bytes uploaded to the remote segment store. +segments.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes for which to upload to the remote segment store after the upload has started. +segments.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes successfully uploaded to the remote segment store. +segments.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes that failed to upload to the remote segment store. +segments.remote_store.upload.refresh_size_lag | Object | The amount of lag during upload between the remote segment store and the local store. +segments.remote_store.upload.refresh_size_lag.total_bytes | Integer | The total bytes that lagged during the upload refresh between the remote segment store and the local store. +segments.remote_store.upload.refresh_size_lag.max_bytes | Integer | The maximum lag in bytes during the upload refresh between the remote segment store and the local store. +segments.remote_store.upload.max_refresh_time_lag_in_millis | Integer | The maximum duration in milliseconds the remote refresh is behind the local refresh. +segments.remote_store.upload.total_time_spent_in_millis | Integer | The total time in milliseconds spent on uploads to the remote segment store. +segments.remote_store.download | Object | Statistics related to download operation to the remote segment store. +segments.remote_store.download.total_download_size | Object | The amount of data downloaded from the remote segment store. +segments.remote_store.download.total_download_size.started_bytes | Integer | The number of bytes downloaded from the remote segment store after the download starts. +segments.remote_store.download.total_download_size.succeeded_bytes | Integer | The number of bytes successfully downloaded from the remote segment store. +segments.remote_store.download.total_download_size.failed_bytes | Integer | The number of bytes that failed to down from the remote segment store. +segments.remote_store.download.total_time_spent_in_millis | Integer | The total duration in milliseconds spent on downloads from the remote segment store. segments.file_sizes | Integer | Statistics about the size of the segment files. translog | Object | Statistics about transaction log operations for the node. translog.operations | Integer | The number of translog operations. @@ -853,16 +853,16 @@ translog.size_in_bytes | Integer | The size of the translog, in bytes. translog.uncommitted_operations | Integer | The number of uncommitted translog operations. translog.uncommitted_size_in_bytes | Integer | The size of uncommitted translog operations, in bytes. translog.earliest_last_modified_age | Integer | The earliest last modified age for the translog. -translog.remote_store | Object | Statistics about Remote Translog Store operations. -translog.remote_store.upload | Object | Statistics about Remote Translog Store upload operations. -translog.remote_store.upload.total_uploads | Object | The number of syncs to Remote Translog Store. -translog.remote_store.upload.total_uploads.started | Integer | The number of syncs to Remote Translog Store that have been started. -translog.remote_store.upload.total_uploads.failed | Integer | The number of syncs to Remote Translog Store that have failed. -translog.remote_store.upload.total_uploads.succeeded | Integer | The number of syncs to Remote Translog Store that have succeeded. -translog.remote_store.upload.total_upload_size | Object | The amount of data uploaded to Remote Translog Store. -translog.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes for which upload to Remote Translog Store has been started. -translog.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes for which upload to Remote Translog Store has failed. -translog.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes for which upload to Remote Translog Store has succeeded. +translog.remote_store | Object | Statistics related to operations from the remote translog store. +translog.remote_store.upload | Object | Statistics about upload operation to the remote translog store. +translog.remote_store.upload.total_uploads | Object | The number of syncs to the remote translog store. +translog.remote_store.upload.total_uploads.started | Integer | The number of upload syncs to the remote translog store that have started. +translog.remote_store.upload.total_uploads.failed | Integer | The number of failed upload syncs to the remote translog store. +translog.remote_store.upload.total_uploads.succeeded | Integer | The number of successful upload syncs to the remote translog store. +translog.remote_store.upload.total_upload_size | Object | The amount of data uploaded to the remote translog store. +translog.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes actively uploading to the remote translog store after the upload has started. +translog.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes that failed to upload to the remote translog store. +translog.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes successfully uploaded to the remote translog store. request_cache | Object | Statistics about the request cache for the node. request_cache.memory_size_in_bytes | Integer | The memory size used by the request cache, in bytes. request_cache.evictions | Integer | The number of request cache evictions. diff --git a/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md b/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md index 707bb6ee29..f3fb09d6f4 100644 --- a/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md +++ b/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md @@ -18,8 +18,8 @@ Remote segment backpressure is a shard-level rejection mechanism that dynamicall Remote segment backpressure is activated if any of the following thresholds is breached: - **Consecutive failure**: The backpressure is activated if there are _N_ or more consecutive failures. The value of _N_ is configurable in `remote_store.segment.pressure.consecutive_failures.limit`. -- **Bytes lag**: The bytes lag is computed by adding the size of all files that are present in local committed segments but not in the remote store. The backpressure is activated if the bytes lag is greater than _K_ multiplied by the moving average of the size (in bytes) of files uploaded after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.bytes_lag.variance_factor`. The moving window size is configurable in `remote_store.moving_average_window_size`. -- **Time lag**: The time lag is computed by comparing the timestamps of the most recent local refresh and the most recent remote store segment upload. The backpressure is activated if the time lag is greater than _K_ multiplied by the moving average of the time taken to upload new segments and metadata file after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.time_lag.variance_factor`. The moving window size is configurable in `remote_store.moving_average_window_size`. +- **Bytes lag**: The bytes lag is computed by adding the size of all files that are present in local committed segments but not in the remote store. Backpressure is activated if the bytes lag is greater than _K_ multiplied by the moving average of the size in, in bytes, of files uploaded after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.bytes_lag.variance_factor`. The moving window size is configurable through the `remote_store.moving_average_window_size` setting. +- **Time lag**: The time lag is computed by comparing the timestamps of the most recent local refresh and the most recent remote store segment upload. Backpressure is activated if the time lag is greater than _K_ multiplied by the moving average of the time taken to upload new segments and metadata file after each refresh. The variance factor _K_ is configurable through `remote_store.segment.pressure.time_lag.variance_factor` setting. The moving window size is configurable through the `remote_store.moving_average_window_size` setting. ## Handling segment merges @@ -42,5 +42,5 @@ The following table lists the settings used for statistics. |Setting |Data type |Description | |:--- |:--- |:--- | -|`remote_store.moving_average_window_size` |Integer | The moving average window size used to calculate the rolling statistic values exposed through [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. | +| `remote_store.moving_average_window_size` | Integer | The moving average window size used to calculate the rolling statistic values exposed through [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. | From 3ddba4fb5f3e5fe0bc331ecc5706ba3196cfe877 Mon Sep 17 00:00:00 2001 From: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> Date: Wed, 13 Sep 2023 11:08:17 -0500 Subject: [PATCH 4/7] Update _api-reference/nodes-apis/nodes-stats.md Signed-off-by: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> --- _api-reference/nodes-apis/nodes-stats.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_api-reference/nodes-apis/nodes-stats.md b/_api-reference/nodes-apis/nodes-stats.md index 3361a7148c..619fb250ce 100644 --- a/_api-reference/nodes-apis/nodes-stats.md +++ b/_api-reference/nodes-apis/nodes-stats.md @@ -830,7 +830,7 @@ segments.version_map_memory_in_bytes | Integer | The total amount of memory used segments.fixed_bit_set_memory_in_bytes | Integer | The total amount of memory used by fixed bit sets, in bytes. Fixed bit sets are used for nested objects and join fields. segments.max_unsafe_auto_id_timestamp | Integer | The timestamp for the most recently retired indexing request, in milliseconds since the epoch. segments.remote_store | Object | Statistics about remote segment store operations. -segments.remote_store.upload | Object | Statistics about Remote Segment Store upload operations. +segments.remote_store.upload | Object | Statistics related to upload operation to the remote segment store. segments.remote_store.upload.total_upload_size | Object | The amount of data in bytes uploaded to the remote segment store. segments.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes for which to upload to the remote segment store after the upload has started. segments.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes successfully uploaded to the remote segment store. From de043b30538edc09ee4db73c6e72f95fd99e8ea5 Mon Sep 17 00:00:00 2001 From: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> Date: Wed, 13 Sep 2023 11:20:25 -0500 Subject: [PATCH 5/7] Update nodes-stats.md Signed-off-by: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> --- _api-reference/nodes-apis/nodes-stats.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/_api-reference/nodes-apis/nodes-stats.md b/_api-reference/nodes-apis/nodes-stats.md index 619fb250ce..8483a66f73 100644 --- a/_api-reference/nodes-apis/nodes-stats.md +++ b/_api-reference/nodes-apis/nodes-stats.md @@ -829,6 +829,10 @@ segments.index_writer_memory_in_bytes | Integer | The total amount of memory use segments.version_map_memory_in_bytes | Integer | The total amount of memory used by all version maps, in bytes. segments.fixed_bit_set_memory_in_bytes | Integer | The total amount of memory used by fixed bit sets, in bytes. Fixed bit sets are used for nested objects and join fields. segments.max_unsafe_auto_id_timestamp | Integer | The timestamp for the most recently retired indexing request, in milliseconds since the epoch. +segments.segment_replication | Object | Segment replication statistics for all primary shards when segment replication is on the node enabled. +segments.segment_replication.maxBytesBehind | long | The max number of bytes behind the primary replica is. +segments.segment_replication.totalBytesBehind | long | The total number of bytes behind the primary replicas are. +segments.segment_replication.maxReplicationLag | long | The maximum time, in milliseconds, taken by a replica to catch up to its primary. segments.remote_store | Object | Statistics about remote segment store operations. segments.remote_store.upload | Object | Statistics related to upload operation to the remote segment store. segments.remote_store.upload.total_upload_size | Object | The amount of data in bytes uploaded to the remote segment store. From c7dcd37d30b80dbfbf52cedaa3f3179ea2bf8ab2 Mon Sep 17 00:00:00 2001 From: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> Date: Wed, 13 Sep 2023 11:21:35 -0500 Subject: [PATCH 6/7] Update cluster-stats.md Signed-off-by: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> --- _api-reference/cluster-api/cluster-stats.md | 1 + 1 file changed, 1 insertion(+) diff --git a/_api-reference/cluster-api/cluster-stats.md b/_api-reference/cluster-api/cluster-stats.md index 8d69cf21f6..93cd021d17 100644 --- a/_api-reference/cluster-api/cluster-stats.md +++ b/_api-reference/cluster-api/cluster-stats.md @@ -514,3 +514,4 @@ nodes.network_types | The transport and HTTP networks within the nodes. nodes.discovery_type | The method the nodes use to find other nodes within the cluster. nodes.packaging_types | Information about the nodes' OpenSearch distribution. nodes.ingest | Information about the nodes' ingest pipelines/nodes, if there are any. +total_time_spent | The total amount of download and upload time take across all shards in the cluster when downloading or uploading from the remote store. From fff4b0813673ccbffa178b387ca0e02da43a6a43 Mon Sep 17 00:00:00 2001 From: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> Date: Wed, 13 Sep 2023 12:48:20 -0500 Subject: [PATCH 7/7] Apply suggestions from code review Co-authored-by: Nathan Bower Signed-off-by: Naarcha-AWS <97990722+Naarcha-AWS@users.noreply.github.com> --- .../cluster-api/cluster-settings.md | 2 +- _api-reference/cluster-api/cluster-stats.md | 2 +- _api-reference/nodes-apis/nodes-stats.md | 34 +++++++++---------- .../remote-segment-backpressure.md | 6 ++-- 4 files changed, 22 insertions(+), 22 deletions(-) diff --git a/_api-reference/cluster-api/cluster-settings.md b/_api-reference/cluster-api/cluster-settings.md index 49c7475ecf..439cfaaf40 100644 --- a/_api-reference/cluster-api/cluster-settings.md +++ b/_api-reference/cluster-api/cluster-settings.md @@ -107,7 +107,7 @@ The following request field parameters are compatible with the cluster API. | cluster.max_shards_per_node | Integer | Limits the total number of primary and replica shards for the cluster. The limit is calculated as follows: `cluster.max_shards_per_node` multiplied by the number of non-frozen data nodes. Shards for closed indexes do not count toward this limit. Default is `1000`. | | cluster.persistent_tasks.allocation.enable | String | Enables or disables allocation for persistent tasks:

`all` – Allows persistent tasks to be assigned to nodes.

`none` – No allocations are allowed for persistent tasks. This does not affect persistent tasks already running.

Default is `all`. | | cluster.persistent_tasks.allocation.recheck_interval | Time unit | The cluster manager automatically checks whether or not persistent tasks need to be assigned when the cluster state changes in a significant way. There are other factors, such as memory usage, that will affect whether or not persistent tasks are assigned to nodes but do not otherwise cause the cluster state to change. This setting defines how often assignment checks are performed in response to these factors. Default is `30 seconds`, with a minimum of `10 seconds` being required. | -| remote_store.moving_average_window_size | Integer | The moving average window size used to calculate the rolling statistic values exposed through [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. | +| remote_store.moving_average_window_size | Integer | The moving average window size used to calculate the rolling statistic values exposed through the [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. | #### Example request diff --git a/_api-reference/cluster-api/cluster-stats.md b/_api-reference/cluster-api/cluster-stats.md index 93cd021d17..1083ff1dc5 100644 --- a/_api-reference/cluster-api/cluster-stats.md +++ b/_api-reference/cluster-api/cluster-stats.md @@ -514,4 +514,4 @@ nodes.network_types | The transport and HTTP networks within the nodes. nodes.discovery_type | The method the nodes use to find other nodes within the cluster. nodes.packaging_types | Information about the nodes' OpenSearch distribution. nodes.ingest | Information about the nodes' ingest pipelines/nodes, if there are any. -total_time_spent | The total amount of download and upload time take across all shards in the cluster when downloading or uploading from the remote store. +total_time_spent | The total amount of download and upload time spent across all shards in the cluster when downloading or uploading from the remote store. diff --git a/_api-reference/nodes-apis/nodes-stats.md b/_api-reference/nodes-apis/nodes-stats.md index 8483a66f73..b17cc3ec38 100644 --- a/_api-reference/nodes-apis/nodes-stats.md +++ b/_api-reference/nodes-apis/nodes-stats.md @@ -829,27 +829,27 @@ segments.index_writer_memory_in_bytes | Integer | The total amount of memory use segments.version_map_memory_in_bytes | Integer | The total amount of memory used by all version maps, in bytes. segments.fixed_bit_set_memory_in_bytes | Integer | The total amount of memory used by fixed bit sets, in bytes. Fixed bit sets are used for nested objects and join fields. segments.max_unsafe_auto_id_timestamp | Integer | The timestamp for the most recently retired indexing request, in milliseconds since the epoch. -segments.segment_replication | Object | Segment replication statistics for all primary shards when segment replication is on the node enabled. -segments.segment_replication.maxBytesBehind | long | The max number of bytes behind the primary replica is. -segments.segment_replication.totalBytesBehind | long | The total number of bytes behind the primary replicas are. -segments.segment_replication.maxReplicationLag | long | The maximum time, in milliseconds, taken by a replica to catch up to its primary. +segments.segment_replication | Object | Segment replication statistics for all primary shards when segment replication is enabled on the node. +segments.segment_replication.maxBytesBehind | long | The maximum number of bytes behind the primary replica. +segments.segment_replication.totalBytesBehind | long | The total number of bytes behind the primary replicas. +segments.segment_replication.maxReplicationLag | long | The maximum amount of time, in milliseconds, taken by a replica to catch up to its primary. segments.remote_store | Object | Statistics about remote segment store operations. -segments.remote_store.upload | Object | Statistics related to upload operation to the remote segment store. -segments.remote_store.upload.total_upload_size | Object | The amount of data in bytes uploaded to the remote segment store. -segments.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes for which to upload to the remote segment store after the upload has started. +segments.remote_store.upload | Object | Statistics related to uploads to the remote segment store. +segments.remote_store.upload.total_upload_size | Object | The amount of data, in bytes, uploaded to the remote segment store. +segments.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes to upload to the remote segment store after the upload has started. segments.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes successfully uploaded to the remote segment store. segments.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes that failed to upload to the remote segment store. segments.remote_store.upload.refresh_size_lag | Object | The amount of lag during upload between the remote segment store and the local store. -segments.remote_store.upload.refresh_size_lag.total_bytes | Integer | The total bytes that lagged during the upload refresh between the remote segment store and the local store. -segments.remote_store.upload.refresh_size_lag.max_bytes | Integer | The maximum lag in bytes during the upload refresh between the remote segment store and the local store. -segments.remote_store.upload.max_refresh_time_lag_in_millis | Integer | The maximum duration in milliseconds the remote refresh is behind the local refresh. -segments.remote_store.upload.total_time_spent_in_millis | Integer | The total time in milliseconds spent on uploads to the remote segment store. -segments.remote_store.download | Object | Statistics related to download operation to the remote segment store. -segments.remote_store.download.total_download_size | Object | The amount of data downloaded from the remote segment store. +segments.remote_store.upload.refresh_size_lag.total_bytes | Integer | The total number of bytes that lagged during the upload refresh between the remote segment store and the local store. +segments.remote_store.upload.refresh_size_lag.max_bytes | Integer | The maximum amount of lag, in bytes, during the upload refresh between the remote segment store and the local store. +segments.remote_store.upload.max_refresh_time_lag_in_millis | Integer | The maximum duration, in milliseconds, that the remote refresh is behind the local refresh. +segments.remote_store.upload.total_time_spent_in_millis | Integer | The total amount of time, in milliseconds, spent on uploads to the remote segment store. +segments.remote_store.download | Object | Statistics related to downloads to the remote segment store. +segments.remote_store.download.total_download_size | Object | The total amount of data download from the remote segment store. segments.remote_store.download.total_download_size.started_bytes | Integer | The number of bytes downloaded from the remote segment store after the download starts. segments.remote_store.download.total_download_size.succeeded_bytes | Integer | The number of bytes successfully downloaded from the remote segment store. -segments.remote_store.download.total_download_size.failed_bytes | Integer | The number of bytes that failed to down from the remote segment store. -segments.remote_store.download.total_time_spent_in_millis | Integer | The total duration in milliseconds spent on downloads from the remote segment store. +segments.remote_store.download.total_download_size.failed_bytes | Integer | The number of bytes that failed to download from the remote segment store. +segments.remote_store.download.total_time_spent_in_millis | Integer | The total duration, in milliseconds, spent on downloads from the remote segment store. segments.file_sizes | Integer | Statistics about the size of the segment files. translog | Object | Statistics about transaction log operations for the node. translog.operations | Integer | The number of translog operations. @@ -858,12 +858,12 @@ translog.uncommitted_operations | Integer | The number of uncommitted translog o translog.uncommitted_size_in_bytes | Integer | The size of uncommitted translog operations, in bytes. translog.earliest_last_modified_age | Integer | The earliest last modified age for the translog. translog.remote_store | Object | Statistics related to operations from the remote translog store. -translog.remote_store.upload | Object | Statistics about upload operation to the remote translog store. +translog.remote_store.upload | Object | Statistics related to uploads to the remote translog store. translog.remote_store.upload.total_uploads | Object | The number of syncs to the remote translog store. translog.remote_store.upload.total_uploads.started | Integer | The number of upload syncs to the remote translog store that have started. translog.remote_store.upload.total_uploads.failed | Integer | The number of failed upload syncs to the remote translog store. translog.remote_store.upload.total_uploads.succeeded | Integer | The number of successful upload syncs to the remote translog store. -translog.remote_store.upload.total_upload_size | Object | The amount of data uploaded to the remote translog store. +translog.remote_store.upload.total_upload_size | Object | The total amount of data uploaded to the remote translog store. translog.remote_store.upload.total_upload_size.started_bytes | Integer | The number of bytes actively uploading to the remote translog store after the upload has started. translog.remote_store.upload.total_upload_size.failed_bytes | Integer | The number of bytes that failed to upload to the remote translog store. translog.remote_store.upload.total_upload_size.succeeded_bytes | Integer | The number of bytes successfully uploaded to the remote translog store. diff --git a/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md b/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md index f3fb09d6f4..76844c21e1 100644 --- a/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md +++ b/_tuning-your-cluster/availability-and-recovery/remote-store/remote-segment-backpressure.md @@ -18,8 +18,8 @@ Remote segment backpressure is a shard-level rejection mechanism that dynamicall Remote segment backpressure is activated if any of the following thresholds is breached: - **Consecutive failure**: The backpressure is activated if there are _N_ or more consecutive failures. The value of _N_ is configurable in `remote_store.segment.pressure.consecutive_failures.limit`. -- **Bytes lag**: The bytes lag is computed by adding the size of all files that are present in local committed segments but not in the remote store. Backpressure is activated if the bytes lag is greater than _K_ multiplied by the moving average of the size in, in bytes, of files uploaded after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.bytes_lag.variance_factor`. The moving window size is configurable through the `remote_store.moving_average_window_size` setting. -- **Time lag**: The time lag is computed by comparing the timestamps of the most recent local refresh and the most recent remote store segment upload. Backpressure is activated if the time lag is greater than _K_ multiplied by the moving average of the time taken to upload new segments and metadata file after each refresh. The variance factor _K_ is configurable through `remote_store.segment.pressure.time_lag.variance_factor` setting. The moving window size is configurable through the `remote_store.moving_average_window_size` setting. +- **Bytes lag**: The bytes lag is calculated by adding the sizes of all the files that are present in local committed segments but not in the remote store. Backpressure is activated if the bytes lag is greater than _K_ multiplied by the moving average of the size, in bytes, of the files uploaded after each refresh. The variance factor _K_ is configurable in `remote_store.segment.pressure.bytes_lag.variance_factor`. The moving window size is configurable through the `remote_store.moving_average_window_size` setting. +- **Time lag**: The time lag is calculated by comparing the timestamps of the most recent local refresh and the most recent remote store segment upload. Backpressure is activated if the time lag is greater than _K_ multiplied by the moving average of the time taken to upload new segments and metadata files after each refresh. The variance factor _K_ is configurable through the `remote_store.segment.pressure.time_lag.variance_factor` setting. The moving window size is configurable through the `remote_store.moving_average_window_size` setting. ## Handling segment merges @@ -42,5 +42,5 @@ The following table lists the settings used for statistics. |Setting |Data type |Description | |:--- |:--- |:--- | -| `remote_store.moving_average_window_size` | Integer | The moving average window size used to calculate the rolling statistic values exposed through [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. | +| `remote_store.moving_average_window_size` | Integer | The moving average window size used to calculate the rolling statistic values exposed through the [Remote Store Stats API]({{site.url}}{{site.baseurl}}/tuning-your-cluster/availability-and-recovery/remote-store/remote-store-stats-api/). Default is `20`. Minimum enforced is `5`. |