2016-06-08 18:32:22 -04:00
|
|
|
[[indices-rollover-index]]
|
|
|
|
== Rollover Index
|
|
|
|
|
2016-06-15 14:57:17 -04:00
|
|
|
The rollover index API rolls an alias over to a new index when the existing
|
|
|
|
index is considered to be too large or too old.
|
2016-06-08 18:32:22 -04:00
|
|
|
|
2016-06-15 14:57:17 -04:00
|
|
|
The API accepts a single alias name and a list of `conditions`. The alias
|
|
|
|
must point to a single index only. If the index satisfies the specified
|
|
|
|
conditions then a new index is created and the alias is switched to point to
|
|
|
|
the new alias.
|
2016-06-08 18:32:22 -04:00
|
|
|
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2016-07-26 14:50:20 -04:00
|
|
|
PUT /logs-000001 <1>
|
2016-06-15 14:57:17 -04:00
|
|
|
{
|
|
|
|
"aliases": {
|
|
|
|
"logs_write": {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-01 17:08:18 -04:00
|
|
|
# Add > 1000 documents to logs-000001
|
|
|
|
|
|
|
|
POST /logs_write/_rollover <2>
|
2016-06-15 14:57:17 -04:00
|
|
|
{
|
|
|
|
"conditions": {
|
|
|
|
"max_age": "7d",
|
|
|
|
"max_docs": 1000
|
|
|
|
}
|
|
|
|
}
|
2016-06-08 18:32:22 -04:00
|
|
|
--------------------------------------------------
|
2016-06-15 14:57:17 -04:00
|
|
|
// CONSOLE
|
2016-09-01 17:08:18 -04:00
|
|
|
// TEST[setup:huge_twitter]
|
|
|
|
// TEST[s/# Add > 1000 documents to logs-000001/POST _reindex?refresh\n{"source":{"index":"twitter"},"dest":{"index":"logs-000001"}}/]
|
2016-07-26 14:50:20 -04:00
|
|
|
<1> Creates an index called `logs-0000001` with the alias `logs_write`.
|
2016-06-15 14:57:17 -04:00
|
|
|
<2> If the index pointed to by `logs_write` was created 7 or more days ago, or
|
|
|
|
contains 1,000 or more documents, then the `logs-0002` index is created
|
2016-07-26 14:50:20 -04:00
|
|
|
and the `logs_write` alias is updated to point to `logs-000002`.
|
2016-06-08 18:32:22 -04:00
|
|
|
|
2016-06-15 14:57:17 -04:00
|
|
|
The above request might return the following response:
|
2016-06-08 18:32:22 -04:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2016-06-15 14:57:17 -04:00
|
|
|
{
|
2016-09-01 17:08:18 -04:00
|
|
|
"acknowledged": true,
|
|
|
|
"shards_acknowledged": true,
|
2016-07-26 14:50:20 -04:00
|
|
|
"old_index": "logs-000001",
|
|
|
|
"new_index": "logs-000002",
|
2016-06-15 14:57:17 -04:00
|
|
|
"rolled_over": true, <1>
|
|
|
|
"dry_run": false, <2>
|
|
|
|
"conditions": { <3>
|
|
|
|
"[max_age: 7d]": false,
|
|
|
|
"[max_docs: 1000]": true
|
|
|
|
}
|
|
|
|
}
|
2016-06-08 18:32:22 -04:00
|
|
|
--------------------------------------------------
|
2016-09-01 17:08:18 -04:00
|
|
|
// TESTRESPONSE
|
2016-06-15 14:57:17 -04:00
|
|
|
<1> Whether the index was rolled over.
|
|
|
|
<2> Whether the rollover was dry run.
|
|
|
|
<3> The result of each condition.
|
2016-06-08 18:32:22 -04:00
|
|
|
|
2016-06-15 14:57:17 -04:00
|
|
|
[float]
|
|
|
|
=== Naming the new index
|
2016-06-08 18:32:22 -04:00
|
|
|
|
2016-06-15 14:57:17 -04:00
|
|
|
If the name of the existing index ends with `-` and a number -- e.g.
|
2016-07-26 14:50:20 -04:00
|
|
|
`logs-000001` -- then the name of the new index will follow the same pattern,
|
|
|
|
incrementing the number (`logs-000002`). The number is zero-padded with a length
|
|
|
|
of 6, regardless of the old index name.
|
2016-06-09 13:43:19 -04:00
|
|
|
|
2016-06-15 14:57:17 -04:00
|
|
|
If the old name doesn't match this pattern then you must specify the name for
|
|
|
|
the new index as follows:
|
2016-06-08 18:32:22 -04:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2016-09-01 17:08:18 -04:00
|
|
|
POST /my_alias/_rollover/my_new_index_name
|
|
|
|
{
|
|
|
|
"conditions": {
|
|
|
|
"max_age": "7d",
|
|
|
|
"max_docs": 1000
|
|
|
|
}
|
|
|
|
}
|
2016-06-15 14:57:17 -04:00
|
|
|
--------------------------------------------------
|
2016-09-01 17:08:18 -04:00
|
|
|
// CONSOLE
|
|
|
|
// TEST[s/^/PUT my_old_index_name\nPUT my_old_index_name\/_alias\/my_alias\n/]
|
2016-06-15 14:57:17 -04:00
|
|
|
|
|
|
|
[float]
|
|
|
|
=== Defining the new index
|
|
|
|
|
2016-06-17 17:31:03 -04:00
|
|
|
The settings, mappings, and aliases for the new index are taken from any
|
|
|
|
matching <<indices-templates,index templates>>. Additionally, you can specify
|
|
|
|
`settings`, `mappings`, and `aliases` in the body of the request, just like the
|
2016-09-01 17:08:18 -04:00
|
|
|
<<indices-create-index,create index>> API. Values specified in the request
|
2016-06-17 17:31:03 -04:00
|
|
|
override any values set in matching index templates. For example, the following
|
|
|
|
`rollover` request overrides the `index.number_of_shards` setting:
|
2016-06-15 14:57:17 -04:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2016-07-26 14:50:20 -04:00
|
|
|
PUT /logs-000001
|
2016-06-17 00:03:28 -04:00
|
|
|
{
|
|
|
|
"aliases": {
|
|
|
|
"logs_write": {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-01 17:08:18 -04:00
|
|
|
POST /logs_write/_rollover
|
2016-06-15 14:57:17 -04:00
|
|
|
{
|
|
|
|
"conditions" : {
|
|
|
|
"max_age": "7d",
|
|
|
|
"max_docs": 1000
|
|
|
|
},
|
2016-09-01 17:08:18 -04:00
|
|
|
"settings": {
|
|
|
|
"index.number_of_shards": 2
|
2016-06-15 14:57:17 -04:00
|
|
|
}
|
|
|
|
}
|
2016-06-08 18:32:22 -04:00
|
|
|
--------------------------------------------------
|
2016-06-15 14:57:17 -04:00
|
|
|
// CONSOLE
|
2016-06-08 18:32:22 -04:00
|
|
|
|
2016-06-17 17:31:03 -04:00
|
|
|
[float]
|
|
|
|
=== Dry run
|
2016-06-08 18:32:22 -04:00
|
|
|
|
2016-06-15 14:57:17 -04:00
|
|
|
The rollover API supports `dry_run` mode, where request conditions can be
|
|
|
|
checked without performing the actual rollover:
|
2016-06-08 18:32:22 -04:00
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
2016-07-26 14:50:20 -04:00
|
|
|
PUT /logs-000001
|
2016-06-17 00:03:28 -04:00
|
|
|
{
|
|
|
|
"aliases": {
|
|
|
|
"logs_write": {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-01 17:08:18 -04:00
|
|
|
POST /logs_write/_rollover?dry_run
|
2016-06-08 18:32:22 -04:00
|
|
|
{
|
2016-06-15 14:57:17 -04:00
|
|
|
"conditions" : {
|
|
|
|
"max_age": "7d",
|
|
|
|
"max_docs": 1000
|
|
|
|
}
|
2016-06-08 18:32:22 -04:00
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2016-06-15 14:57:17 -04:00
|
|
|
// CONSOLE
|
2016-06-08 18:32:22 -04:00
|
|
|
|
2016-08-02 09:15:01 -04:00
|
|
|
[float]
|
|
|
|
=== Wait For Active Shards
|
|
|
|
|
2016-09-01 17:08:18 -04:00
|
|
|
Because the rollover operation creates a new index to rollover to, the
|
|
|
|
<<create-index-wait-for-active-shards,wait for active shards>> setting on
|
2016-08-02 09:15:01 -04:00
|
|
|
index creation applies to the rollover action as well.
|