在前面提到的,重建索引的问题是必须更新应用中的索引名称。 索引别名就是用来解决这个问题的!
索引 别名 就像一个快捷方式或软连接,可以指向一个或多个索引,也可以给任何一个需要索引名的API来使用。别名 带给我们极大的灵活性,允许我们做下面这些:
- 在运行的集群中可以无缝的从一个索引切换到另一个索引
- 给多个索引分组 (例如,
last_three_months
)
- 给索引的一个子集创建
视图
在后面我们会讨论更多关于别名的使用。现在,我们将解释怎样使用别名在零停机下从旧索引切换到新索引。
有两种方式管理别名: _alias
用于单个操作, _aliases
用于执行多个原子级操作
//检测哪些别名指向这个索引
GET /duomaicrm_customer_wide_751308485/_alias/*
//这个别名指向哪些索引
GET /*/_alias/duomaicrm_customer_wide_alias_751308485
//切换别名指向:将别名duomaicrm_customer_wide_alias_751308485 指向到duomaicrm_customer_wide_7513084852
PUT /duomaicrm_customer_wide_7513084852/_alias/duomaicrm_customer_wide_alias_751308485
//将别名指向另外一个索引并移除之前的指向,因为别名可以同时指向多个索引
POST /_aliases
{
"actions": [
{ "remove": { "index": "duomaicrm_customer_wide_7513084852", "alias": "duomaicrm_customer_wide_alias_751308485" }},
{"add":{"index":"duomaicrm_customer_wide_751308485","alias": "duomaicrm_customer_wide_alias_751308485"}}
]
}