rollover-index.asciidoc 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. [[indices-rollover-index]]
  2. == Rollover Index
  3. The rollover index API rolls an alias over to a new index when the existing
  4. index is considered to be too large or too old.
  5. The API accepts a single alias name and a list of `conditions`. The alias
  6. must point to a single index only. If the index satisfies the specified
  7. conditions then a new index is created and the alias is switched to point to
  8. the new alias.
  9. [source,js]
  10. --------------------------------------------------
  11. PUT /logs-000001 <1>
  12. {
  13. "aliases": {
  14. "logs_write": {}
  15. }
  16. }
  17. POST logs_write/_rollover <2>
  18. {
  19. "conditions": {
  20. "max_age": "7d",
  21. "max_docs": 1000
  22. }
  23. }
  24. --------------------------------------------------
  25. // CONSOLE
  26. <1> Creates an index called `logs-0000001` with the alias `logs_write`.
  27. <2> If the index pointed to by `logs_write` was created 7 or more days ago, or
  28. contains 1,000 or more documents, then the `logs-0002` index is created
  29. and the `logs_write` alias is updated to point to `logs-000002`.
  30. The above request might return the following response:
  31. [source,js]
  32. --------------------------------------------------
  33. {
  34. "old_index": "logs-000001",
  35. "new_index": "logs-000002",
  36. "rolled_over": true, <1>
  37. "dry_run": false, <2>
  38. "conditions": { <3>
  39. "[max_age: 7d]": false,
  40. "[max_docs: 1000]": true
  41. }
  42. }
  43. --------------------------------------------------
  44. <1> Whether the index was rolled over.
  45. <2> Whether the rollover was dry run.
  46. <3> The result of each condition.
  47. [float]
  48. === Naming the new index
  49. If the name of the existing index ends with `-` and a number -- e.g.
  50. `logs-000001` -- then the name of the new index will follow the same pattern,
  51. incrementing the number (`logs-000002`). The number is zero-padded with a length
  52. of 6, regardless of the old index name.
  53. If the old name doesn't match this pattern then you must specify the name for
  54. the new index as follows:
  55. [source,js]
  56. --------------------------------------------------
  57. POST my_alias/_rollover/my_new_index_name
  58. {...}
  59. --------------------------------------------------
  60. [float]
  61. === Defining the new index
  62. The settings, mappings, and aliases for the new index are taken from any
  63. matching <<indices-templates,index templates>>. Additionally, you can specify
  64. `settings`, `mappings`, and `aliases` in the body of the request, just like the
  65. <<indices-create-index,create index>> API. Values specified in the request
  66. override any values set in matching index templates. For example, the following
  67. `rollover` request overrides the `index.number_of_shards` setting:
  68. [source,js]
  69. --------------------------------------------------
  70. PUT /logs-000001
  71. {
  72. "aliases": {
  73. "logs_write": {}
  74. }
  75. }
  76. POST logs_write/_rollover
  77. {
  78. "conditions" : {
  79. "max_age": "7d",
  80. "max_docs": 1000
  81. },
  82. "settings": {
  83. "index.number_of_shards": 2
  84. }
  85. }
  86. --------------------------------------------------
  87. // CONSOLE
  88. [float]
  89. === Dry run
  90. The rollover API supports `dry_run` mode, where request conditions can be
  91. checked without performing the actual rollover:
  92. [source,js]
  93. --------------------------------------------------
  94. PUT /logs-000001
  95. {
  96. "aliases": {
  97. "logs_write": {}
  98. }
  99. }
  100. POST logs_write/_rollover?dry_run
  101. {
  102. "conditions" : {
  103. "max_age": "7d",
  104. "max_docs": 1000
  105. }
  106. }
  107. --------------------------------------------------
  108. // CONSOLE
  109. [float]
  110. === Wait For Active Shards
  111. Because the rollover operation creates a new index to rollover to, the
  112. <<create-index-wait-for-active-shards,wait for active shards>> setting on
  113. index creation applies to the rollover action as well.