Elasticsearch 8 支持别名查询

在 Elasticsearch 8 中,使用 Java 高级 REST 客户端进行别名管理的过程与之前的版本类似,但有一些API细节上的变化。以下是如何使用 Java 和 Elasticsearch 8 进行别名操作的例子:

引入依赖

确保你的项目中包含了 Elasticsearch 的高级 REST 客户端依赖。对于 Maven,你可能需要如下依赖:

复制代码

Xml

深色版本

复制代码
1<dependency>
2    <groupId>org.elasticsearch.client</groupId>
3    <artifactId>elasticsearch-rest-high-level-client</artifactId>
4    <version>8.0.0</version>
5</dependency>

创建索引

首先,你需要创建一个新的索引:

复制代码

Java

深色版本

复制代码
1import org.elasticsearch.action.admin.indices.create.CreateIndexRequest;
2import org.elasticsearch.client.RequestOptions;
3import org.elasticsearch.client.RestHighLevelClient;
4
5RestHighLevelClient client = new RestHighLevelClient(...);
6CreateIndexRequest request = new CreateIndexRequest("new_index");
7client.indices().create(request, RequestOptions.DEFAULT);

定义别名

接着,定义一个别名并将其关联到你的新索引上:

复制代码

Java

深色版本

复制代码
1import org.elasticsearch.action.admin.indices.alias.put.Alias;
2import org.elasticsearch.action.admin.indices.alias.put.PutAliasRequest;
3
4PutAliasRequest aliasRequest = new PutAliasRequest("new_index").alias("my_alias");
5client.indices().putAlias(aliasRequest, RequestOptions.DEFAULT);

重定向别名

当你准备好将流量从旧索引重定向到新索引时,可以先删除旧索引上的别名,然后再将别名添加到新索引上:

复制代码

Java

深色版本

复制代码
1import org.elasticsearch.action.admin.indices.alias.delete.DeleteAliasesRequest;
2
3DeleteAliasesRequest deleteRequest = new DeleteAliasesRequest();
4deleteRequest.indices("old_index");
5deleteRequest.aliases("my_alias");
6client.indices().deleteAlias(deleteRequest, RequestOptions.DEFAULT);
7
8// 然后将别名添加到新索引上
9aliasRequest = new PutAliasRequest("new_index").alias("my_alias");
10client.indices().putAlias(aliasRequest, RequestOptions.DEFAULT);

数据写入

当别名被正确设置后,你的应用程序只需要向别名发送写入请求,而不需要关心实际的索引名称:

复制代码

Java

深色版本

复制代码
1import org.elasticsearch.action.index.IndexRequest;
2import org.elasticsearch.common.xcontent.XContentType;
3
4IndexRequest indexRequest = new IndexRequest("my_alias")
5    .source(jsonString, XContentType.JSON);
6client.index(indexRequest, RequestOptions.DEFAULT);

注意事项

  • 在删除旧别名和添加新别名的过程中,确实存在一个短暂的时间窗口,在此期间,查询可能无法找到数据。为了减小这种影响,你可以使用 Elasticsearch 的 indices.put_alias API 中的 wait_for_active_shards 参数来等待所有分片变为活动状态后再继续下一步操作。
  • 在生产环境中,确保在进行切换前对新索引进行了充分的测试,确保其设置正确,且数据导入已完成。
  • 监控别名操作的状态,确保没有出现异常情况。

查看别名

GET /_aliases

GET /_alias/content_erp_nlp_help_alia

在 Elasticsearch 中,当你使用别名进行查询时,实际上的流程是这样的:

  1. 解析别名: 当你向 Elasticsearch 发送一个请求,其中包含别名而不是具体的索引名称时,Elasticsearch 会首先解析这个别名,找出所有与该别名相关的实际索引。

  2. 转发请求: 解析出实际的索引后,Elasticsearch 会将查询请求转发到这些索引上。这意味着,如果你的别名指向了多个索引,查询将会同时在这些索引上执行。

  3. 收集和汇总结果: 每个被查询的索引都会返回自己的结果集。Elasticsearch 会收集这些结果,并将它们汇总在一起,形成一个统一的响应返回给客户端。

  4. 返回结果: 最终,客户端接收到的查询结果看起来就像是从一个单一的索引获得的一样,尽管实际上可能涉及到了多个索引。

因此,当你使用别名查询时,Elasticsearch 的内部机制是将这个查询转换为对多个具体索引的查询,然后处理这些索引的结果,以提供一个统一的视图。这种方式使得维护和查询多个逻辑相关的索引变得更为方便,特别是当涉及到滚动更新或索引重构时,别名可以作为稳定的入口点,而不会影响到使用这些别名的应用程序。

相关推荐
Avan_菜菜2 小时前
FRP 内网穿透完整实战:从 HTTP 映射到 HTTPS 自签代理
运维·nginx·https
SelectDB1 天前
Litefuse 开源并推出单进程轻量模式,25 秒就能跑起来的 Agent 可观测与评估平台
运维·后端·自动化运维
XIAOHEZIcode2 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220703 天前
如何搭建本地yum源(上)
运维
大树886 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠6 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质6 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工6 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智6 天前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_6 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化