The add alias request allows us to alias an existing index to another name:
val resp = client.execute {
aliases add "places" on "locations"
}
Aliases can include filters to assist with partitioning data (such as limiting results to a certain customer or project) or commonly applied filtering:
val resp = client.execute {
aliases add "uk-locations" on "locations" filter FilterBuilders.termFilter("country", "uk") routing 4
}
Existing aliases can be removed using a similar request:
val resp = client.execute {
aliases remove "places" on "locations"
}
Multiple operations on aliases can be executed atomically:
val resp = client.execute {
aliases(
aliases remove "places" on "old_locations",
aliases add "places" on "new_locations"
)
}
For more information on the options for aliases, consult the official ElasticSearch docs.