Rollover

Rollover

Phases allowed: hot.

Rolls over a target to a new index when the existing index satisfies the specified rollover conditions.

When an index is rolled over, the previous index’s age is updated to reflect the rollover time. This date, rather than the index’s creation_date, is used in index lifecycle management min_age phase calculations. Learn more.

If the rollover action is used on a follower index, policy execution waits until the leader index rolls over (or is otherwise marked complete), then converts the follower index into a regular index with the Unfollow action.

A rollover target can be a data stream or an index alias. When targeting a data stream, the new index becomes the data stream’s write index and its generation is incremented.

To roll over an index alias, the alias and its write index must meet the following conditions:

  • The index name must match the pattern ^.*-\d+$, for example (my-index-000001).
  • The index.lifecycle.rollover_alias must be configured as the alias to roll over.
  • The index must be the write index for the alias.

For example, if my-index-000001 has the alias my_data, the following settings must be configured.

  1. resp = client.indices.create(
  2. index="my-index-000001",
  3. settings={
  4. "index.lifecycle.name": "my_policy",
  5. "index.lifecycle.rollover_alias": "my_data"
  6. },
  7. aliases={
  8. "my_data": {
  9. "is_write_index": True
  10. }
  11. },
  12. )
  13. print(resp)
  1. response = client.indices.create(
  2. index: 'my-index-000001',
  3. body: {
  4. settings: {
  5. 'index.lifecycle.name' => 'my_policy',
  6. 'index.lifecycle.rollover_alias' => 'my_data'
  7. },
  8. aliases: {
  9. my_data: {
  10. is_write_index: true
  11. }
  12. }
  13. }
  14. )
  15. puts response
  1. const response = await client.indices.create({
  2. index: "my-index-000001",
  3. settings: {
  4. "index.lifecycle.name": "my_policy",
  5. "index.lifecycle.rollover_alias": "my_data",
  6. },
  7. aliases: {
  8. my_data: {
  9. is_write_index: true,
  10. },
  11. },
  12. });
  13. console.log(response);
  1. PUT my-index-000001
  2. {
  3. "settings": {
  4. "index.lifecycle.name": "my_policy",
  5. "index.lifecycle.rollover_alias": "my_data"
  6. },
  7. "aliases": {
  8. "my_data": {
  9. "is_write_index": true
  10. }
  11. }
  12. }

Options

A rollover action must specify at least one max_* condition, it may include zero or more min_* conditions. An empty rollover action is invalid.

The index will roll over once any max_* condition is satisfied and all min_* conditions are satisfied. Note, however, that empty indices are not rolled over by default.

max_age

(Optional, time units) Triggers 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.

max_docs

(Optional, integer) Triggers 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.

max_size

(Optional, 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.

max_primary_shard_size

(Optional, 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 each shard, and prirep indicates whether a shard is a primary (p) or a replica (r).

max_primary_shard_docs

(Optional, integer) Triggers rollover when the largest primary shard in the index reaches a certain number of documents. This is the maximum docs of the primary shards in the index. As with max_docs, replicas are ignored.

To see the current shard docs, use the _cat shards API. The docs value shows the number of documents each shard.

min_age

(Optional, time units) Prevents rollover until after the minimum elapsed time from index creation is reached. See notes on max_age.

min_docs

(Optional, integer) Prevents rollover until after the specified minimum number of documents is reached. See notes on max_docs.

min_size

(Optional, byte units) Prevents rollover until the index reaches a certain size. See notes on max_size.

min_primary_shard_size

(Optional, byte units) Prevents rollover until the largest primary shard in the index reaches a certain size. See notes on max_primary_shard_size.

min_primary_shard_docs

(Optional, integer) Prevents rollover until the largest primary shard in the index reaches a certain number of documents. See notes on max_primary_shard_docs.

Empty indices will not be rolled over, even if they have an associated max_age that would otherwise result in a roll over occurring. A policy can override this behavior, and explicitly opt in to rolling over empty indices, by adding a "min_docs": 0 condition. This can also be disabled on a cluster-wide basis by setting indices.lifecycle.rollover.only_if_has_documents to false.

The rollover action implicitly always rolls over a data stream or alias if one or more shards contain 200000000 or more documents. Normally a shard will reach 50GB long before it reaches 200M documents, but this isn’t the case for space efficient data sets. Search performance will very likely suffer if a shard contains more than 200M documents. This is the reason of the builtin limit.

Example

Roll over based on largest primary shard size

This example rolls the index over when its largest primary shard is at least 50 gigabytes.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_primary_shard_size": "50gb"
  9. }
  10. }
  11. }
  12. }
  13. },
  14. )
  15. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_primary_shard_size: '50gb'
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }
  16. )
  17. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_primary_shard_size: "50gb",
  9. },
  10. },
  11. },
  12. },
  13. },
  14. });
  15. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover" : {
  8. "max_primary_shard_size": "50gb"
  9. }
  10. }
  11. }
  12. }
  13. }
  14. }

Roll over based on index size

This example rolls the index over when it is at least 100 gigabytes.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_size": "100gb"
  9. }
  10. }
  11. }
  12. }
  13. },
  14. )
  15. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_size: '100gb'
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }
  16. )
  17. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_size: "100gb",
  9. },
  10. },
  11. },
  12. },
  13. },
  14. });
  15. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover" : {
  8. "max_size": "100gb"
  9. }
  10. }
  11. }
  12. }
  13. }
  14. }

Roll over based on document count

This example rolls the index over when it contains at least one hundred million documents.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_docs": 100000000
  9. }
  10. }
  11. }
  12. }
  13. },
  14. )
  15. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_docs: 100_000_000
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }
  16. )
  17. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_docs: 100000000,
  9. },
  10. },
  11. },
  12. },
  13. },
  14. });
  15. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover" : {
  8. "max_docs": 100000000
  9. }
  10. }
  11. }
  12. }
  13. }
  14. }

Roll over based on document count of the largest primary shard

This example rolls the index over when it contains at least ten million documents of the largest primary shard.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_primary_shard_docs": 10000000
  9. }
  10. }
  11. }
  12. }
  13. },
  14. )
  15. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_primary_shard_docs: 10_000_000
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }
  16. )
  17. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_primary_shard_docs: 10000000,
  9. },
  10. },
  11. },
  12. },
  13. },
  14. });
  15. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover" : {
  8. "max_primary_shard_docs": 10000000
  9. }
  10. }
  11. }
  12. }
  13. }
  14. }

Roll over based on index age

This example rolls the index over if it was created at least 7 days ago.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_age": "7d"
  9. }
  10. }
  11. }
  12. }
  13. },
  14. )
  15. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_age: '7d'
  10. }
  11. }
  12. }
  13. }
  14. }
  15. }
  16. )
  17. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_age: "7d",
  9. },
  10. },
  11. },
  12. },
  13. },
  14. });
  15. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover" : {
  8. "max_age": "7d"
  9. }
  10. }
  11. }
  12. }
  13. }
  14. }

Roll over using multiple conditions

When you specify multiple rollover conditions, the index is rolled over when any of the max_* and all of the min_* conditions are met. This example rolls the index over if it is at least 7 days old or at least 100 gigabytes, but only as long as the index contains at least 1000 documents.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_age": "7d",
  9. "max_size": "100gb",
  10. "min_docs": 1000
  11. }
  12. }
  13. }
  14. }
  15. },
  16. )
  17. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_age: '7d',
  10. max_size: '100gb',
  11. min_docs: 1000
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }
  18. )
  19. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_age: "7d",
  9. max_size: "100gb",
  10. min_docs: 1000,
  11. },
  12. },
  13. },
  14. },
  15. },
  16. });
  17. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover" : {
  8. "max_age": "7d",
  9. "max_size": "100gb",
  10. "min_docs": 1000
  11. }
  12. }
  13. }
  14. }
  15. }
  16. }

Roll over while maintaining shard sizes

This example rolls the index over when the primary shard size is at least 50gb, or when the index is at least 30 days old, but only as long as a primary shard is at least 1gb. For low-volume indices, this prevents the creation of many small shards.

  1. resp = client.ilm.put_lifecycle(
  2. name="my_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_primary_shard_size": "50gb",
  9. "max_age": "30d",
  10. "min_primary_shard_size": "1gb"
  11. }
  12. }
  13. }
  14. }
  15. },
  16. )
  17. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'my_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_primary_shard_size: '50gb',
  10. max_age: '30d',
  11. min_primary_shard_size: '1gb'
  12. }
  13. }
  14. }
  15. }
  16. }
  17. }
  18. )
  19. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "my_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_primary_shard_size: "50gb",
  9. max_age: "30d",
  10. min_primary_shard_size: "1gb",
  11. },
  12. },
  13. },
  14. },
  15. },
  16. });
  17. console.log(response);
  1. PUT _ilm/policy/my_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover" : {
  8. "max_primary_shard_size": "50gb",
  9. "max_age": "30d",
  10. "min_primary_shard_size": "1gb"
  11. }
  12. }
  13. }
  14. }
  15. }
  16. }

Rollover condition blocks phase transition

The rollover action only completes if one of its conditions is met. This means that any subsequent phases are blocked until rollover succeeds.

For example, the following policy deletes the index one day after it rolls over. It does not delete the index one day after it was created.

  1. resp = client.ilm.put_lifecycle(
  2. name="rollover_policy",
  3. policy={
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_size": "50gb"
  9. }
  10. }
  11. },
  12. "delete": {
  13. "min_age": "1d",
  14. "actions": {
  15. "delete": {}
  16. }
  17. }
  18. }
  19. },
  20. )
  21. print(resp)
  1. response = client.ilm.put_lifecycle(
  2. policy: 'rollover_policy',
  3. body: {
  4. policy: {
  5. phases: {
  6. hot: {
  7. actions: {
  8. rollover: {
  9. max_size: '50gb'
  10. }
  11. }
  12. },
  13. delete: {
  14. min_age: '1d',
  15. actions: {
  16. delete: {}
  17. }
  18. }
  19. }
  20. }
  21. }
  22. )
  23. puts response
  1. const response = await client.ilm.putLifecycle({
  2. name: "rollover_policy",
  3. policy: {
  4. phases: {
  5. hot: {
  6. actions: {
  7. rollover: {
  8. max_size: "50gb",
  9. },
  10. },
  11. },
  12. delete: {
  13. min_age: "1d",
  14. actions: {
  15. delete: {},
  16. },
  17. },
  18. },
  19. },
  20. });
  21. console.log(response);
  1. PUT /_ilm/policy/rollover_policy
  2. {
  3. "policy": {
  4. "phases": {
  5. "hot": {
  6. "actions": {
  7. "rollover": {
  8. "max_size": "50gb"
  9. }
  10. }
  11. },
  12. "delete": {
  13. "min_age": "1d",
  14. "actions": {
  15. "delete": {}
  16. }
  17. }
  18. }
  19. }
  20. }