Elasticsearch--索引别名

作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO

联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬

学习必须往深处挖,挖的越深,基础越扎实!

阶段1、深入多线程

阶段2、深入多线程设计模式

阶段3、深入juc源码解析


阶段4、深入jdk其余源码解析


阶段5、深入jvm源码解析

码哥源码部分

码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】

码哥讲源码【炸雷啦!炸雷啦!黄光头他终于跑路啦!】

码哥讲源码-【jvm课程前置知识及c/c++调试环境搭建】

​​​​​​码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】

码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】

码哥讲源码【你水不是你的错,但是你胡说八道就是你不对了!】

码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】

终结B站没人能讲清楚红黑树的历史,不服等你来踢馆!

打脸系列【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/*
  • 13
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值