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_aliasAPI 中的wait_for_active_shards参数来等待所有分片变为活动状态后再继续下一步操作。 - 在生产环境中,确保在进行切换前对新索引进行了充分的测试,确保其设置正确,且数据导入已完成。
- 监控别名操作的状态,确保没有出现异常情况。
------------------------------------------------------------------------
查看别名
GET /_aliases
GET /_alias/content_erp_nlp_help_alia

在 Elasticsearch 中,当你使用别名进行查询时,实际上的流程是这样的:
-
解析别名: 当你向 Elasticsearch 发送一个请求,其中包含别名而不是具体的索引名称时,Elasticsearch 会首先解析这个别名,找出所有与该别名相关的实际索引。
-
转发请求: 解析出实际的索引后,Elasticsearch 会将查询请求转发到这些索引上。这意味着,如果你的别名指向了多个索引,查询将会同时在这些索引上执行。
-
收集和汇总结果: 每个被查询的索引都会返回自己的结果集。Elasticsearch 会收集这些结果,并将它们汇总在一起,形成一个统一的响应返回给客户端。
-
返回结果: 最终,客户端接收到的查询结果看起来就像是从一个单一的索引获得的一样,尽管实际上可能涉及到了多个索引。
因此,当你使用别名查询时,Elasticsearch 的内部机制是将这个查询转换为对多个具体索引的查询,然后处理这些索引的结果,以提供一个统一的视图。这种方式使得维护和查询多个逻辑相关的索引变得更为方便,特别是当涉及到滚动更新或索引重构时,别名可以作为稳定的入口点,而不会影响到使用这些别名的应用程序。
相关文章:
Elasticsearch 8 支持别名查询
在 Elasticsearch 8 中,使用 Java 高级 REST 客户端进行别名管理的过程与之前的版本类似,但有一些API细节上的变化。以下是如何使用 Java 和 Elasticsearch 8 进行别名操作的例子: 引入依赖 确保你的项目中包含了 Elasticsearch 的高级 RES…...
【Spring Cloud】 使用Eureka实现服务注册与服务发现
文章目录 🍃前言🎍解决方案🚩关于注册中⼼🚩CAP理论🚩常见的注册中心 🎄Eureka🚩搭建 Eureka Server🎈创建Eureka-server ⼦模块🎈引入依赖🎈项目构建插件&am…...
JDK安装详细教程(以JDK17为例)
一、JDK的下载 1. 前往oracle官网下载JDK Java Archive Downloads - Java SE 17 在这里选择对应的JDK版本,我这里就直接选择JDK17的版本了。 然后下载对应的软件包,我这里采用的是Windows的安装程序。 点击上述圈起来的链接即可下载安装包,…...
安装nodejs | npm报错
nodejs安装步骤: 官网:https://nodejs.org/en/ 在官网下载nodejs: 双击下载下来的msi安装包,一直点next,我选的安装目录是默认的: 测试是否安装成功: 输入cmd打开命令提示符,输入node -v可以看到版本,说…...
聊点基础---Java和.NET开发技术异同全方位分析
1. C#语言基础 1.1 C#语法概览 欢迎来到C#的世界!对于刚从Java转过来的开发者来说,你会发现C#和Java有很多相似之处,但C#也有其独特的魅力和强大之处。让我们一起来探索C#的基本语法,并比较一下与Java的异同。 程序结构 C#程序…...
【C++】C++中SDKDDKVer.h和WinSDKVer.h函数库详解
目录 一.SDKDDKVer.h介绍 二.WinSDKVer.h介绍 三.WinSDKVer.h 和 SDKDDKVer.h 的区别 一.SDKDDKVer.h介绍 SDKDDKVer.h 是一个在 Windows 软件开发中常见的头文件,它用于定义软件开发工具包(SDK)和驱动开发工具包(DDK&…...
uni-app 蓝牙传输
https://www.cnblogs.com/ckfuture/p/16450418.html https://www.cnblogs.com/yangxiaobai123/p/16021058.html 字符串转base64:https://www.cnblogs.com/sunny3158/p/17312158.html 将 ArrayBuffer 对象转成 Base64 字符串:基础 - uni.arrayBufferT…...
MBR10200CT-ASEMI智能AI应用MBR10200CT
编辑:ll MBR10200CT-ASEMI智能AI应用MBR10200CT 型号:MBR10200CT 品牌:ASEMI 封装:TO-220 批号:最新 恢复时间:35ns 最大平均正向电流(IF):10A 最大循环峰值反向…...
力扣 爬楼梯
动态规划算法基础篇。 class Solution {public int climbStairs(int n) {int[] f new int[n 1];f[0] 1;f[1] 1;//当爬到n阶楼梯时,可知是由n-1阶或n-2阶楼梯而来for(int i 2; i < n; i) {f[i] f[i - 1] f[i - 2];//后面的每一阶种数由前两个状态得到}ret…...
java设计模式之:策略模式+工厂模式整合案例实战(一)
本文介绍项目中常用的策略模式工厂模式的案例,该案例是针对策略类比较少的情况;下一篇会讲解策略类比较多的案例,下面直接开始: 案例1:项目中对系统中的客户和销售进行事件通知(短信、邮件、钉钉) 首先要有通知的策略…...
国内Ubuntu安装 stable-diffusion教程,换成国内镜像
安装依赖: 首先更新系统并安装Python 3.10和pip: sudo apt update sudo apt install python3.10 python3-pip 设置Python虚拟环境(可选): 安装Python虚拟环境管理工具,并创建激活虚拟环境: su…...
JAVA final详细介绍
一、介绍 final 中文意思: 最后的,最终的. final 可以修饰类、属性、方法和局部变量, 在某些情况下,程序员可能有以下需求,就会使用到final: 1)当不希望类被继承时,可以用final修饰。 //如果我们要求A类不能被其他类继承 //可以使用fin…...
45、tomcat+课后实验
tomcat 1、tomcat tomcat和php一样,都是用来处理动态页面的。 tomcat也可以作为web应用服务器,开源的。 php .php tomcat .jsp nginx .html tomcat 是用Java代码写的程序,运行的是Java的web应用程序。 tomcat的特点和功能:…...
设计模式的七大原则
1.单一职责原则 单一职责原则(Single responsibility principle),即一个类应该只负责一项职责。如类A负责两个不同职责:职责1,职责2。当职责1需求变更而改变A时,可能造成职责2执行错误,所以需要将类A的粒度分解为A1、…...
ThreeJS-3D教学十五:ShaderMaterial(noise、random)
ThreeJS-3D教学十四:ShaderMaterial(length、fract、step) 上面这篇主要是操作 fragmentShader 片元着色器,实现对物体颜色的修改,这次咱们来看下修改 vertexShader 顶点着色器,这个其实就是位移各个顶点的位置。 接下来我们先介绍下 noise 噪声函数(Perlin Noise、Sim…...
LeetCode 2974.最小数字游戏:排序+交换奇偶位
【LetMeFly】2974.最小数字游戏:排序交换奇偶位 力扣题目链接:https://leetcode.cn/problems/minimum-number-game/ 你有一个下标从 0 开始、长度为 偶数 的整数数组 nums ,同时还有一个空数组 arr 。Alice 和 Bob 决定玩一个游戏ÿ…...
使用vllIm部署大语言模型
使用vllm部署大语言模型一般需要以下步骤: 一、准备工作 1. 系统要求 - 操作系统:常见的 Linux 发行版(如 Ubuntu、CentOS)或 Windows(通过 WSL)。 - GPU 支持:NVIDIA GPU 并安装了适当的驱动程…...
静态搜索iOS动态链接函数的调用位置
静态搜索iOS动态链接函数的调用位置 可执行文件格式mach-O,是在苹果的操作系统 macOS 和 iOS 上使用的一种二进制文件格式。 在一些iOS安全扫描中,可能存在需要获取函数具体调用位置的需求,能指导用户更精确的定位漏洞。 现在以NSLog函数为例ÿ…...
【鸿蒙学习笔记】尺寸设置・layoutWeight・对子组件进行重新布局
官方文档:尺寸设置 目录标题 layoutWeight:对子组件进行重新布局 layoutWeight:对子组件进行重新布局 设置了layoutWeight属性的子元素与兄弟元素占主轴尺寸按照权重进行分配,忽略元素本身尺寸设置。 // 引入包名 import { http…...
vue实现表单输入框数字类型校验功能
vue实现表单输入框数字类型校验功能 1. 样式代码 <el-form-item label"订单总价"><el-input size"small" v-model"form.totalPrice" placeholder"请输入订单总价 正整数或者2位数小数" input"check(form.totalPric…...
图片转Word怎么转?2026年图片转文档完整方法与工具对比
日常工作中,我们经常需要将拍摄的照片、截图或扫描的纸质文件转换成可编辑的Word文档。无论是转录会议笔记、整理手写资料,还是数字化办公文件,高效的转换工具能显著提升工作效率。本文将详细介绍多种图片转word文档的方法,帮你找…...
Spring Security权限进阶:用@PostAuthorize和@PostFilter保护你的API返回数据(Spring Boot 3.x实战)
Spring Security权限进阶:用PostAuthorize和PostFilter保护你的API返回数据(Spring Boot 3.x实战) 在构建现代Web应用时,数据安全始终是开发者面临的核心挑战之一。传统权限控制往往聚焦于"入口检查"——确保只有合法用…...
Keil5编译报错‘Target not created’?别急着重装,先试试这几招(附常见原因排查清单)
Keil5编译报错‘Target not created’的深度排查指南 当Keil5编译时出现"Target not created"的提示,很多开发者第一反应是重装软件。但实际上,这个报错背后可能隐藏着多种原因,盲目重装不仅浪费时间,还可能掩盖真正的问…...
别再用math.atan了!用NumPy的angle函数处理复数相位,效率提升不止一点点
别再用math.atan了!用NumPy的angle函数处理复数相位,效率提升不止一点点 在信号处理、图像分析和科学计算领域,复数相位计算是基础但关键的操作。许多开发者习惯性地使用math.atan(y/x)来计算角度,却不知道NumPy提供的angle()函数…...
InfluxDB Studio:专业级时间序列数据库管理工具的终极指南
InfluxDB Studio:专业级时间序列数据库管理工具的终极指南 【免费下载链接】InfluxDBStudio InfluxDB Studio is a UI management tool for the InfluxDB time series database. 项目地址: https://gitcode.com/gh_mirrors/in/InfluxDBStudio 在当今数据驱动…...
【职场】为什么越努力的人,在职场死得越惨?
为什么越努力的人,在职场死得越惨? ——没有人告诉你,努力本身是一种暴露。一、先说一个你亲眼见过,但从没想明白的现象 你身边一定有这样的人: 工作最拼的那个,最后被裁了。 加班最多的那个,升…...
3个核心优化:让你的华硕笔记本性能翻倍且更省电
3个核心优化:让你的华硕笔记本性能翻倍且更省电 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops with nearly the same functionality. Works with ROG Zephyrus, Flow, TUF, Strix, Scar, ProArt, Vivobook, Zenbook, Expertbo…...
终极指南:3分钟解决微信网页版无法访问的难题
终极指南:3分钟解决微信网页版无法访问的难题 【免费下载链接】wechat-need-web 让微信网页版可用 / Allow the use of WeChat via webpage access 项目地址: https://gitcode.com/gh_mirrors/we/wechat-need-web 还在为微信网页版无法访问而烦恼吗ÿ…...
阿里云ECS新手避坑指南:搞定校园网、安全组和SSH端口映射(附XShell连接测试)
阿里云ECS新手全流程配置手册:从安全组到SSH连接的深度实践 第一次接触云服务器时,那种既兴奋又忐忑的心情我至今记忆犹新。看着控制台里各种陌生的术语和选项,明明按照教程一步步操作却总是卡在连接阶段,这种经历想必不少技术爱好…...
Qt QUdpSocket组播发送失败?别慌,这3个坑我帮你踩过了(附Windows/Linux代码)
Qt QUdpSocket组播发送失败的3个实战排查点与跨平台解决方案 第一次在Qt项目中使用QUdpSocket实现组播通信时,那种"代码明明没报错但数据就是发不出去"的焦虑感我至今记忆犹新。组播技术本应简化一对多通信的场景,但当你在Windows开发机上测试…...
