别名
编辑别名
编辑别名是数据流或索引组的第二个名称。大多数 Elasticsearch API 接受别名来代替数据流或索引名称。
您可以随时更改别名的关联数据流或索引。如果您的应用程序在 Elasticsearch 请求中使用了别名,则可以在不停止服务或更改应用程序代码的情况下重新索引数据。
别名类型
编辑别名有两种类型:
- 一个 数据流别名 指向一个或多个数据流。
- 一个 索引别名 指向一个或多个索引。
别名不能同时指向数据流和索引。您也不能将数据流的底层索引添加到索引别名中。
添加别名
编辑要将现有数据流或索引添加到别名,请使用 别名 API 的 add
操作。如果别名不存在,则请求会创建它。
resp = client.indices.update_aliases( actions=[ { "add": { "index": "logs-nginx.access-prod", "alias": "logs" } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { add: { index: 'logs-nginx.access-prod', alias: 'logs' } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { add: { index: "logs-nginx.access-prod", alias: "logs", }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "add": { "index": "logs-nginx.access-prod", "alias": "logs" } } ] }
API 的 index
和 indices
参数支持通配符 (*
)。匹配数据流和索引的通配符模式将返回错误。
resp = client.indices.update_aliases( actions=[ { "add": { "index": "logs-*", "alias": "logs" } } ], ) print(resp)
const response = await client.indices.updateAliases({ actions: [ { add: { index: "logs-*", alias: "logs", }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "add": { "index": "logs-*", "alias": "logs" } } ] }
删除别名
编辑要删除别名,请使用别名 API 的 remove
操作。
resp = client.indices.update_aliases( actions=[ { "remove": { "index": "logs-nginx.access-prod", "alias": "logs" } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { remove: { index: 'logs-nginx.access-prod', alias: 'logs' } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { remove: { index: "logs-nginx.access-prod", alias: "logs", }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "remove": { "index": "logs-nginx.access-prod", "alias": "logs" } } ] }
多个操作
编辑您可以使用别名 API 在单个原子操作中执行多个操作。
例如,logs
别名指向单个数据流。以下请求交换了别名的关联数据流。在此交换过程中,logs
别名没有停机时间,并且从未同时指向两个数据流。
resp = client.indices.update_aliases( actions=[ { "remove": { "index": "logs-nginx.access-prod", "alias": "logs" } }, { "add": { "index": "logs-my_app-default", "alias": "logs" } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { remove: { index: 'logs-nginx.access-prod', alias: 'logs' } }, { add: { index: 'logs-my_app-default', alias: 'logs' } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { remove: { index: "logs-nginx.access-prod", alias: "logs", }, }, { add: { index: "logs-my_app-default", alias: "logs", }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "remove": { "index": "logs-nginx.access-prod", "alias": "logs" } }, { "add": { "index": "logs-my_app-default", "alias": "logs" } } ] }
多个操作的结果
编辑使用多个操作时,如果一些操作成功而另一些操作失败,则会返回每个操作的结果列表。
考虑一个与上一个示例类似的操作列表,但现在使用一个名为 log-non-existing
的别名,该别名尚不存在。在这种情况下,remove
操作将失败,但 add
操作将成功。响应将包含列表 action_results
,其中包含每个请求操作的结果。
resp = client.indices.update_aliases( actions=[ { "remove": { "index": "index1", "alias": "logs-non-existing" } }, { "add": { "index": "index2", "alias": "logs-non-existing" } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { remove: { index: 'index1', alias: 'logs-non-existing' } }, { add: { index: 'index2', alias: 'logs-non-existing' } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { remove: { index: "index1", alias: "logs-non-existing", }, }, { add: { index: "index2", alias: "logs-non-existing", }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "remove": { "index": "index1", "alias": "logs-non-existing" } }, { "add": { "index": "index2", "alias": "logs-non-existing" } } ] }
API 返回以下结果:
{ "acknowledged": true, "errors": true, "action_results": [ { "action": { "type": "remove", "indices": [ "index1" ], "aliases": [ "logs-non-existing" ], }, "status": 404, "error": { "type": "aliases_not_found_exception", "reason": "aliases [logs-non-existing] missing", "resource.type": "aliases", "resource.id": "logs-non-existing" } }, { "action": { "type": "add", "indices": [ "index2" ], "aliases": [ "logs-non-existing" ], }, "status": 200 } ] }
允许操作列表部分成功可能无法提供所需的结果。设置 must_exist
为 true
可能更合适,如果单个操作失败,这将导致整个操作列表失败。
在索引创建时添加别名
编辑您还可以使用 组件 或 索引模板 在创建索引或数据流时添加索引或数据流别名。
resp = client.cluster.put_component_template( name="my-aliases", template={ "aliases": { "my-alias": {} } }, ) print(resp) resp1 = client.indices.put_index_template( name="my-index-template", index_patterns=[ "my-index-*" ], composed_of=[ "my-aliases", "my-mappings", "my-settings" ], template={ "aliases": { "yet-another-alias": {} } }, ) print(resp1)
response = client.cluster.put_component_template( name: 'my-aliases', body: { template: { aliases: { "my-alias": {} } } } ) puts response response = client.indices.put_index_template( name: 'my-index-template', body: { index_patterns: [ 'my-index-*' ], composed_of: [ 'my-aliases', 'my-mappings', 'my-settings' ], template: { aliases: { "yet-another-alias": {} } } } ) puts response
const response = await client.cluster.putComponentTemplate({ name: "my-aliases", template: { aliases: { "my-alias": {}, }, }, }); console.log(response); const response1 = await client.indices.putIndexTemplate({ name: "my-index-template", index_patterns: ["my-index-*"], composed_of: ["my-aliases", "my-mappings", "my-settings"], template: { aliases: { "yet-another-alias": {}, }, }, }); console.log(response1);
# Component template with index aliases PUT _component_template/my-aliases { "template": { "aliases": { "my-alias": {} } } } # Index template with index aliases PUT _index_template/my-index-template { "index_patterns": [ "my-index-*" ], "composed_of": [ "my-aliases", "my-mappings", "my-settings" ], "template": { "aliases": { "yet-another-alias": {} } } }
您还可以在 创建索引 API 请求中指定索引别名。
resp = client.indices.create( index="<my-index-{now/d}-000001>", aliases={ "my-alias": {} }, ) print(resp)
response = client.indices.create( index: '<my-index-{now/d}-000001>', body: { aliases: { "my-alias": {} } } ) puts response
const response = await client.indices.create({ index: "<my-index-{now/d}-000001>", aliases: { "my-alias": {}, }, }); console.log(response);
# PUT <my-index-{now/d}-000001> PUT %3Cmy-index-%7Bnow%2Fd%7D-000001%3E { "aliases": { "my-alias": {} } }
查看别名
编辑要获取集群别名的列表,请使用 获取别名 API 而不带任何参数。
resp = client.indices.get_alias() print(resp)
response = client.indices.get_alias puts response
const response = await client.indices.getAlias(); console.log(response);
GET _alias
在 _alias
之前指定数据流或索引以查看其别名。
resp = client.indices.get_alias( index="my-data-stream", ) print(resp)
response = client.indices.get_alias( index: 'my-data-stream' ) puts response
const response = await client.indices.getAlias({ index: "my-data-stream", }); console.log(response);
GET my-data-stream/_alias
在 _alias
之后指定别名以查看其数据流或索引。
resp = client.indices.get_alias( name="logs", ) print(resp)
response = client.indices.get_alias( name: 'logs' ) puts response
const response = await client.indices.getAlias({ name: "logs", }); console.log(response);
GET _alias/logs
写入索引
编辑您可以使用 is_write_index
为别名指定写入索引或数据流。Elasticsearch 将别名的任何写入请求路由到此索引或数据流。
resp = client.indices.update_aliases( actions=[ { "add": { "index": "logs-nginx.access-prod", "alias": "logs" } }, { "add": { "index": "logs-my_app-default", "alias": "logs", "is_write_index": True } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { add: { index: 'logs-nginx.access-prod', alias: 'logs' } }, { add: { index: 'logs-my_app-default', alias: 'logs', is_write_index: true } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { add: { index: "logs-nginx.access-prod", alias: "logs", }, }, { add: { index: "logs-my_app-default", alias: "logs", is_write_index: true, }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "add": { "index": "logs-nginx.access-prod", "alias": "logs" } }, { "add": { "index": "logs-my_app-default", "alias": "logs", "is_write_index": true } } ] }
如果别名指向多个索引或数据流并且未设置 is_write_index
,则别名将拒绝写入请求。如果索引别名指向一个索引并且未设置 is_write_index
,则该索引会自动充当写入索引。数据流别名不会自动设置写入数据流,即使别名指向一个数据流也是如此。
我们建议使用数据流来存储追加式时间序列数据。如果您需要更新或删除现有时间序列数据,您可以直接在数据流底层索引上执行更新或删除操作。如果您经常使用相同的 _id
发送多个文档并期望最后写入获胜,则可能需要使用带有写入索引的索引别名。请参阅 在不使用数据流的情况下管理时间序列数据。
过滤别名
编辑filter
选项使用 查询 DSL 来限制别名可以访问的文档。
resp = client.indices.update_aliases( actions=[ { "add": { "index": "my-index-2099.05.06-000001", "alias": "my-alias", "filter": { "bool": { "filter": [ { "range": { "@timestamp": { "gte": "now-1d/d", "lt": "now/d" } } }, { "term": { "user.id": "kimchy" } } ] } } } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { add: { index: 'my-index-2099.05.06-000001', alias: 'my-alias', filter: { bool: { filter: [ { range: { "@timestamp": { gte: 'now-1d/d', lt: 'now/d' } } }, { term: { 'user.id' => 'kimchy' } } ] } } } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { add: { index: "my-index-2099.05.06-000001", alias: "my-alias", filter: { bool: { filter: [ { range: { "@timestamp": { gte: "now-1d/d", lt: "now/d", }, }, }, { term: { "user.id": "kimchy", }, }, ], }, }, }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "add": { "index": "my-index-2099.05.06-000001", "alias": "my-alias", "filter": { "bool": { "filter": [ { "range": { "@timestamp": { "gte": "now-1d/d", "lt": "now/d" } } }, { "term": { "user.id": "kimchy" } } ] } } } } ] }
路由
编辑使用 routing
选项将别名的请求 路由 到特定的分片。这使您可以利用 分片缓存 来加快搜索速度。数据流别名不支持路由选项。
resp = client.indices.update_aliases( actions=[ { "add": { "index": "my-index-2099.05.06-000001", "alias": "my-alias", "routing": "1" } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { add: { index: 'my-index-2099.05.06-000001', alias: 'my-alias', routing: '1' } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { add: { index: "my-index-2099.05.06-000001", alias: "my-alias", routing: "1", }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "add": { "index": "my-index-2099.05.06-000001", "alias": "my-alias", "routing": "1" } } ] }
使用 index_routing
和 search_routing
为索引和搜索指定不同的路由值。如果指定,这些选项将覆盖其各自操作的 routing
值。
resp = client.indices.update_aliases( actions=[ { "add": { "index": "my-index-2099.05.06-000001", "alias": "my-alias", "search_routing": "1", "index_routing": "2" } } ], ) print(resp)
response = client.indices.update_aliases( body: { actions: [ { add: { index: 'my-index-2099.05.06-000001', alias: 'my-alias', search_routing: '1', index_routing: '2' } } ] } ) puts response
const response = await client.indices.updateAliases({ actions: [ { add: { index: "my-index-2099.05.06-000001", alias: "my-alias", search_routing: "1", index_routing: "2", }, }, ], }); console.log(response);
POST _aliases { "actions": [ { "add": { "index": "my-index-2099.05.06-000001", "alias": "my-alias", "search_routing": "1", "index_routing": "2" } } ] }