作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO
联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬
学习必须往深处挖,挖的越深,基础越扎实!
阶段1、深入多线程
阶段2、深入多线程设计模式
阶段3、深入juc源码解析
码哥源码部分
码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】
码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】
码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】
码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】
打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】
索引别名
在Elasticsearch所有的API中,对应的是一个或者多个索引。Elasticsearch可以对一个或者多个索引指定别名,通过别名可以查询到一个或者多个索引的内容。在内部,Elasticsearch会自动把别名映射到相应的索引上。可以对别名编写过滤器或者路由,在系统中别名**不能重复** ,也不能和索引名重复。
示为索引secisland增加一个别名alias1
POST /_aliases
{
"actions": [
{
"add": {
"index": "secisland",
"alias": "alias1"
}
}
]
}
删除别名:与请求是一样的,参数不一样:
POST /_aliases
{
"actions": [
{
"remove": {
"index": "secisland",
"alias": "alias1"
}
}
]
}
注意:
别名没有修改的语法,当需要修改别名的时候,可以先删除别名,然后再增加别名,例如:
POST /_aliases
{
"actions": [
{
"remove": {
"index": "secisland",
"alias": "alias1"
}
},
{
"add": {
"index": "secisland",
"alias": "alias2"
}
}
]
}
一个别名关联多个索引:
POST /_aliases
{
"actions":[
{"add":{"index":"test1","alias":"alias1"}},
{"add":{"index":"test2","alias":"alias1"}}
]
}
或
{
"actions":[
{"add":{"indices":["test1","test2"],"alias":"alias"}}
]
}
或使用通配符
{
"actions":[
{"add":{"index":"test*","alias":"all_test_indices"}}
]
}
删除别名
语法:
DELETE /{index}/_alias/{/name}
示例:删除secisland的别名alias2
DELETE /secisland/_alias/alias2
查询现有别名
可以通过索引名或者别名进行查询,参数如下:
- index:索引别名的名称。部分支持通配符,用逗号分隔也可以指定多个索引名称,还可以使用索引的别名名称。
- alias:在相应中返回别名名称。该参数支持通配符和用逗号分隔的多个别名。
- ignore_unavailable:如果一个指定的索引名称不存在,可以设置为true,这些索引将被忽略。
语法:
GET /{index}/_alias/{alias}
示例:查询索引secisland的所有别名
GET /secisland/_alias/*
返回:
{
"secisland": {
"aliases": {
"alias3": {},
"alias4": {}
}
}
}
也可以使用HEAD检查别名是否存在,语法和GET类似
HEAD /_alias/2013
HEAD /_alias/2013_01*
HEAD /users/_alias/*
标签:index,alias,--,secisland,别名,索引,源码,Elasticsearch
From: https://blog.csdn.net/smart_an/article/details/140624766