Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add Rollover API #7685

Merged
merged 9 commits into from
Jul 22, 2024
196 changes: 196 additions & 0 deletions _api-reference/index-apis/rollover.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,196 @@
---
layout: default
title: Rollover Index
parent: Index APIs
nav_order: 63
---

# Rollover Index

Check failure on line 8 in _api-reference/index-apis/rollover.md

View workflow job for this annotation

GitHub Actions / vale

[vale] _api-reference/index-apis/rollover.md#L8

[OpenSearch.HeadingCapitalization] 'Rollover Index' is a heading and should be in sentence case.
Raw output
{"message": "[OpenSearch.HeadingCapitalization] 'Rollover Index' is a heading and should be in sentence case.", "location": {"path": "_api-reference/index-apis/rollover.md", "range": {"start": {"line": 8, "column": 3}}}, "severity": "ERROR"}
Introduced 1.0
{: .label .label-purple }

The Rollover Index API creates a new index for a data stream or index alias is subject to the `wait_for_active_shards` setting.

## Path and HTTP methods

```json
POST /<rollover-target>/_rollover/
POST /<rollover-target>/_rollover/<target-index>
```

## Types of rollovers
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

You can rollover a data stream, an index alias with one index, or an index alias with a write index.

Check failure on line 23 in _api-reference/index-apis/rollover.md

View workflow job for this annotation

GitHub Actions / vale

[vale] _api-reference/index-apis/rollover.md#L23

[OpenSearch.RolloverVerb] Use 'roll over' as a verb instead of 'rollover'.
Raw output
{"message": "[OpenSearch.RolloverVerb] Use 'roll over' as a verb instead of 'rollover'.", "location": {"path": "_api-reference/index-apis/rollover.md", "range": {"start": {"line": 23, "column": 9}}}, "severity": "ERROR"}
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### A data stream
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

When you perform a rollover operation on a data stream, the API generates a fresh write index for that stream. Simultaneously, the stream's preceding write index transitions into a regular backing index. Additionally, the rollover process increments the generation count of the data stream. Data Stream rollovers do not support specifying index settings in the request body.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### An index alias with one index
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

When you initiate a rollover on an index alias that is associated with a single index, the API will generate a brand-new index for that alias. Then, it will disassociate the original index from the alias.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### An index alias with a write index
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

In cases where an index alias references multiple indexes, one of those indexes must be designated as the **write** index. When performing a rollover on such an alias, the API will create a fresh index to serve as the new write index, with its `is_write_index` property set to `true`. Simultaneously, the API will update the previous write index by setting its `is_write_index` property to `false`.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

## Incrementing index names for an alias

During the rollover process of an index alias, you have the option to provide a custom name for the new index being created. However, if you choose not to specify a name and the current index's name ends with a hyphen followed by a number, for example, `my-index-000001` or `my-index-3`, the rollover operation will automatically increment that number for the new index's name. For instance, if you roll over an alias with a current index named `my-index-000001`, the rollover will generate a new index named `my-index-000002`. It's important to note that this numeric portion is always padded with leading zeros to ensure a consistent length of six characters, regardless of the previous index's name format.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

## Using date math with index rollovers

When utilizing an index alias for time-series data, you can leverage [date math](https://opensearch.org/docs/latest/field-types/supported-field-types/date/) in the index name to keep track of the rollover date. For instance, you could create an alias that points to an index named `my-index-{now/d}-000001`. If you create this index on June 11, 2029, the resulting index name would be my-index-2029.06.11-000001. Subsequently, if you perform a rollover on this alias on June 12, 2029, the new index created would be named my-index-2029.06.12-000002. For a practical example demonstrating this concept, see [Roll over an index alias with a write index](#rolling-over-an-index-alias-with-a-write-index).

Check failure on line 43 in _api-reference/index-apis/rollover.md

View workflow job for this annotation

GitHub Actions / vale

[vale] _api-reference/index-apis/rollover.md#L43

[OpenSearch.Range] Use an en dash (--) with no space on either side in a range of numbers.
Raw output
{"message": "[OpenSearch.Range] Use an en dash (--) with no space on either side in a range of numbers.", "location": {"path": "_api-reference/index-apis/rollover.md", "range": {"start": {"line": 43, "column": 403}}}, "severity": "ERROR"}

Check failure on line 43 in _api-reference/index-apis/rollover.md

View workflow job for this annotation

GitHub Actions / vale

[vale] _api-reference/index-apis/rollover.md#L43

[OpenSearch.Range] Use an en dash (--) with no space on either side in a range of numbers.
Raw output
{"message": "[OpenSearch.Range] Use an en dash (--) with no space on either side in a range of numbers.", "location": {"path": "_api-reference/index-apis/rollover.md", "range": {"start": {"line": 43, "column": 540}}}, "severity": "ERROR"}
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

## Path parameters

The Rollover Index API supports the following parameters.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

Parameter | Type | Description
:--- | :--- | :---
`<rollover-target>` | String | The name of the data stream or index alias to roll over. Required. |
`<target-index>` | String | The name of the index to create. Supports date math. Data streams do not support this parameter. If the name of the alias's current write index does not end with - and a number, such as `my-index-000001` or `my-index-2`, this parameter is required.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

## Query parameters

The following query parameters are supported.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

Parameter | Type | Description
:--- | :--- | :---
`cluster_manager_timeout` | Time | The amount of time to wait for a connection to the cluster manager node. Default is `30s`
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`timeout` | Time | How long to wait for a response. Default is `30s`.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`wait_for_active_shards` | String | The number of active shards that must be available before OpenSearch processes the request. Default is `1` (only the primary shard). You can also set to `all` or a positive integer. Values greater than 1 require replicas. For example, if you specify a value of 3, the index must have two replicas distributed across two additional nodes for the operation to succeed.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

## Request body

The following request body options are supported.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### `alias`

The alias name as the key. Required when the `template` option exists in the request body.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

The object body contains the following optional options for the alias:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

Parameter | Type | Description
:--- | :--- | :---
`filter` | Query DSL object | The query that limits documents the alias can access.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Let's clarify a bit. Limits what about the documents? "limits the number of documents"?

`index_routing` | String | The value which routes indexing operations to a specific shard. When specified, overwrites the `routing` value for indexing operations.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`is_hidden` | Boolean | When `true`, the alias is hidden. Default is false. All indexes for the alias must have matching values for this setting.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`is_write_index` | Boolean | When `true`, the index is the [write index] for the alias. Default is `false`.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`routing` | String | The value used to route index and search operations to a specific shard.
`search_routing` | String | The value used to write specifically search operations to a specific shard. When specified, this option overwrites the `routing` value for search operations.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### `mappings`

The field mappings that exist in the index. For more information, see [Mappings and field types](https://opensearch.org/docs/latest/field-types/). Optional.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### `conditions`

The conditions parameter is an optional object that allows you to define specific criteria for triggering the rollover operation. When provided, OpenSearch only runs the rollover if the current index satisfies one or more of the specified conditions. However, if this parameter is omitted, OpenSerch will perform the rollover unconditionally, without any prerequisite conditions.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

The object body supports the following options.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

Parameter | Type | Description
:--- | :--- | :---
| `max_age` | Time units | Triggers a rollover after the maximum elapsed time from index creation is reached. The elapsed time is always calculated since the index creation time, even if the index origination date is configured to a custom date, such as when using the `index.lifecycle.parse_origination_date` or `index.lifecycle.origination_date` settings. Optional. |
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`max_docs` | Integer | Triggers a rollover after the specified maximum number of documents is reached. Documents added since the last refresh are not included in the document count. The document count does not include documents in replica shards. Optional
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`max_size` | Byte units | Triggers rollover when the index reaches a certain size. This is the total size of all primary shards in the index. Replicas are not counted toward the maximum index size. To see the current index size, use the `_cat indices` API. The `pri.store.size` value shows the combined size of all primary shards. Optional.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
`max_primary_shard_size` | Byte units | Triggers rollover when the largest primary shard in the index reaches a certain size. This is the maximum size of the primary shards in the index. As with `max_size`, replicas are ignored. To see the current shard size, use the `_cat shards` API. The `store` value shows the size of each shard, and `prirep` indicates whether a shard is a primary (`p`) or a replica (`r`). Optional.
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### `settings`

Any configuration options for the index. For more information, see [Index settings](https://opensearch.org/docs/latest/install-and-configure/configuring-opensearch/index-settings/).
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

## Examples

The following example requests and responses illustrate how to use the Rollover Index API. All examples use the following roll over conditions, if one or more of which are met, a roll over occurs:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

- The index was created 5 or more days ago.
- The index contains 500 or more documents.
- The index’s largest primary shard is 100GB or larger.

Check warning on line 110 in _api-reference/index-apis/rollover.md

View workflow job for this annotation

GitHub Actions / vale

[vale] _api-reference/index-apis/rollover.md#L110

[OpenSearch.UnitsSpacing] Put a space between the number and the units in '100GB '.
Raw output
{"message": "[OpenSearch.UnitsSpacing] Put a space between the number and the units in '100GB '.", "location": {"path": "_api-reference/index-apis/rollover.md", "range": {"start": {"line": 110, "column": 40}}}, "severity": "WARNING"}
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

### Rolling over a data stream

The following request only rolls over the data stream if the current write index:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

```
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

json?

Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
POST my-data-stream/_rollover
{
"conditions": {
"max_age": "5d",
"max_docs": 500,
"max_primary_shard_size": "100gb"
}
}
```
{% include copy-curl.html %}

### Rolling over an index alias with a write index

The following request creates a data time index and sets it as the write index for my-alias:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

```
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

json?

Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
PUT <my-index-{now/d}-000001>
PUT %3Cmy-index-%7Bnow%2Fd%7D-000001%3E
{
"aliases": {
"my-alias": {
"is_write_index": true
}
}
}
```
{% include copy-curl.html %}

Than, the next request creates a rollover based off of the alias:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

```
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

json?

Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
POST my-alias/_rollover
{
"conditions": {
"max_age": "5d",
"max_docs": 500,
"max_primary_shard_size": "100gb"
}
}
```
{% include copy-curl.html %}

### Specifying settings during a rollover

In most cases, you can use an index template to automatically configure the indexes created during a rollover operation. However, when rolling over an index alias, you can use the Rollover Index API to introduce additional index settings or override the settings defined in the template, as shown in the following example:
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

```
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

json?

Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
POST my-alias/_rollover
{
"settings": {
"index.number_of_shards": 4
}
}
```
{% include copy-curl.html %}


## Example Response

Check failure on line 174 in _api-reference/index-apis/rollover.md

View workflow job for this annotation

GitHub Actions / vale

[vale] _api-reference/index-apis/rollover.md#L174

[OpenSearch.HeadingCapitalization] 'Example Response' is a heading and should be in sentence case.
Raw output
{"message": "[OpenSearch.HeadingCapitalization] 'Example Response' is a heading and should be in sentence case.", "location": {"path": "_api-reference/index-apis/rollover.md", "range": {"start": {"line": 174, "column": 4}}}, "severity": "ERROR"}
Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved

OpenSearch returns the following response, where all conditions were met as true:

```
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

json?

Naarcha-AWS marked this conversation as resolved.
Show resolved Hide resolved
{
"acknowledged": true,
"shards_acknowledged": true,
"old_index": ".ds-my-data-stream-2029.06.11-000001",
"new_index": ".ds-my-data-stream-2029.06.12-000002",
"rolled_over": true,
"dry_run": false,
"conditions": {
"[max_age: 5d]": true,
"[max_docs: 500]": true,
"[max_primary_shard_size: 100gb]": false
}
}
```




Loading