Spring Data访问Elasticsearch(一)----Elasticsearch客户端

Spring Data访问Elasticsearch(一)----Elasticsearch客户端

  • 一、命令式Rest客户端
  • 二、反应式(Reactive)Rest客户端
  • 三、客户端配置
    • 3.1 客户端配置回调
      • 3.1.1 底层Elasticsearch RestClient的配置:
      • 3.1.2 底层Elasticsearch RestClient使用的HttpAsyncClient配置:
  • 四、客户端日志

本文演示了支持的Elasticsearch客户端实现的配置和使用。Spring Data Elasticsearch运行在一个连接到单个Elasticsearch节点或集群的Elasticsearch客户端上(由Elasticsearch客户端库提供)。虽然Elasticsearch客户端可以直接与集群一起工作,但使用Spring Data Elasticsearch的应用程序通常使用Elasticsearch操作和Elasticsearch存储库的更高级别抽象。

一、命令式Rest客户端

要使用命令式(非响应式)客户端,必须像这样配置bean:

@Configuration
public class MyClientConfig extends ElasticsearchConfiguration {@Overridepublic ClientConfiguration clientConfiguration() {return ClientConfiguration.builder()           --------1.connectedTo("localhost:9200").build();}
}1. 有关构建器方法的详细说明,请参见章节三客户端配置

ElasticsearchConfiguration类允许通过重写例如jsonpMapper()或transportOptions()方法进行进一步配置。
然后可以将以下beans注入到其他Spring组件中:

ElasticsearchOperations operations;      --------1@Autowired
ElasticsearchClient elasticsearchClient; --------2@Autowired
RestClient restClient;                   --------3@Autowired
JsonpMapper jsonpMapper;                 --------41. ElasticsearchOperations的一种实现
2. 使用的co.elastic.clients.elasticsearch.ElasticsearchClient3. Elasticsearch库中的低级RestClient
4. Elasticsearch传输的JsonpMapper用户

基本上,应该使用ElasticsearchOperations与Elasticsearch集群交互。当使用存储库(repositories)时,这个实例也在底层使用。

二、反应式(Reactive)Rest客户端

当使用反应式技术栈时,配置必须从另一个类派生:

@Configuration
public class MyClientConfig extends ReactiveElasticsearchConfiguration {@Overridepublic ClientConfiguration clientConfiguration() {return ClientConfiguration.builder()           --------1.connectedTo("localhost:9200").build();}
}1. 有关构建器方法的详细说明,请参见章节三客户端配置

ReactiveElasticsearchConfiguration类允许通过重写例如jsonpMapper()或transportOptions()方法进行进一步配置。
然后可以将以下bean注入到其他Spring组件中:

@Autowired
ReactiveElasticsearchOperations operations;      --------1@Autowired
ReactiveElasticsearchClient elasticsearchClient; --------2@Autowired
RestClient restClient;                           --------3@Autowired
JsonpMapper jsonpMapper;                         --------41. ReactiveElasticsearchOperations的一个实现
2. 使用的org.springframework.data.elasticsearch.client.elc.ReactiveElasticsearchClient。这是一个基于Elasticsearch客户端实现的反应式实现。
3. Elasticsearch库中的低级RestClient
4. Elasticsearch传输的JsonpMapper用户

基本上,应该只使用ReactiveElasticsearchOperations与Elasticsearch集群进行交互。当使用存储库(repositories)时,这个实例也在底层使用。

三、客户端配置

客户端行为可以通过ClientConfiguration更改,该ClientConfiguration允许设置SSL、connect和socket超时、headers和其他参数的选项。
例1:客户端配置

HttpHeaders httpHeaders = new HttpHeaders();
httpHeaders.add("some-header", "on every request") --------1                     ClientConfiguration clientConfiguration = ClientConfiguration.builder().connectedTo("localhost:9200", "localhost:9291") --------2                     .usingSsl()                                      --------3                     .withProxy("localhost:8888")                     --------4                     .withPathPrefix("ela")                           --------5                     .withConnectTimeout(Duration.ofSeconds(5))       --------6                     .withSocketTimeout(Duration.ofSeconds(3))        --------7                     .withDefaultHeaders(defaultHeaders)              --------8                     .withBasicAuth(username, password)               --------9                     .withHeaders(() -> {                             --------10                     HttpHeaders headers = new HttpHeaders();headers.add("currentTime", LocalDateTime.now().format(DateTimeFormatter.ISO_LOCAL_DATE_TIME));return headers;}).withClientConfigurer(                           --------11                     ElasticsearchClientConfigurationCallback.from(clientBuilder -> {// ...return clientBuilder;})). // ... other options.build();1. 定义默认标头(如果需要自定义)
2. 使用构建器提供集群地址、设置默认HttpHeaders或启用SSL3. 可选地启用SSL。该函数存在重载,可以采用SSLContext,也可以在启动时由Elasticsearch 8输出证书指纹。
4. (可选)设置代理。
5. (可选)设置路径前缀,主要用于不同集群后面的一些反向代理。
6. 设置连接超时。
7. 设置socket超时。
8. (可选)设置headers。
9. 添加基本身份验证。
10. 可以指定一个Supplier<HttpHeaders>函数,该函数在每次向Elasticsearch发送请求之前都会被调用——例如,在这里,当前时间被写入标头中。
11. 可以多次添加一个用于配置创建的客户端的函数(请参阅3.1客户端配置回调)。

如上面的例子所示,添加Header supplier允许注入可能随时间变化的headers,比如身份验证JWT令牌。如果在反应式设置中使用此方法,则supplier函数不能阻塞!

3.1 客户端配置回调

ClientConfiguration类提供了用于配置客户端的最常见参数。如果这还不够,用户可以使用withClientConfigurer(ClientConfigurationCallback<?>)方法添加回调函数。
提供了以下回调:

3.1.1 底层Elasticsearch RestClient的配置:

3.1.2 底层Elasticsearch RestClient使用的HttpAsyncClient配置:

四、客户端日志

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/738246.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

掌握Go语言:精通Go语言运算符,解锁编程新境界(11)

算术运算符用于执行基本的数学运算&#xff0c;如加法、减法、乘法和除法等。在Go语言中&#xff0c;我们可以轻松使用这些运算符来进行数值计算&#xff0c;从而实现各种复杂的逻辑操作。让我们一起来深入了解各种算术运算符的使用方法及其在实际开发中的应用。 算术运算符 …

FFmpeg将视频包AVPacket通过视频流方式写入本地文件

1.写视频头 void writeVideoHeader(const char* videoFileName){int r avformat_alloc_output_context2(&pFormatCtx, nullptr, nullptr,videoFileName);if(r < 0){qDebug()<<"Error: avformat_alloc_output_context2: "<<av_err2str(r);return;…

Python 字符串引号 题解

Python 字符串引号 题解 预备知识 在 Python 中&#xff0c;可以使用引号 &#xff0c;" &#xff0c; 和 """来创建字符串。以下都是合法的字符串&#xff1a; aa aa bb "bb" cc cc dd """dd"""配对的引号不…

CloudSecOps实践之路:云安全运营全面解析

云计算已经获得了大量企业用户的青睐&#xff0c;并成为其数字化转型发展的基础&#xff0c;但是也面临着各种各样的风险&#xff0c;从勒索软件到供应链攻击&#xff0c;再到云内部威胁和配置错误&#xff0c;各种云安全事件层出不穷。随着更多的企业将其业务应用迁移至云端&a…

02_electron快速建立项目

一、安装 yarn 在此之前可以先安装 git&#xff1a;Git - Downloads (git-scm.com) 下面就是 yarn 安装的代码&#xff0c;在终端输入即可。 npm install --global yarn 检查是否安装成功&#xff1a; yarn --version 二、快速建立一个electron项目 其实在Getting Started - …

MYSQL Unknown column ‘appreciation.latitude‘ in ‘where clause‘

问题 笔者编写mysql语句&#xff0c;执行报错 详细问题 笔者sql代码 SELECT ap.*, su.username, wh.wheat_name FROM appreciation ap LEFT JOIN sys_user su ON su.id ap.user_id LEFT JOIN wheat wh ON wh.id ap.crop_id WHERE appreciation.latitude 1报错信息 >…

LeetCode707:设计链表

题目描述 实现 MyLinkedList 类&#xff1a; MyLinkedList() 初始化 MyLinkedList 对象。 int get(int index) 获取链表中下标为 index 的节点的值。如果下标无效&#xff0c;则返回 -1 。 void addAtHead(int val) 将一个值为 val 的节点插入到链表中第一个元素之前。在插入完…

GO语言-切片底层探索(下)

目录 切片的底层数据结构 扩容机制 总结&#xff1a; 练习验证代码 这是切片的底层探索下篇&#xff0c;上篇地址请见&#xff1a;GO语言-切片底层探索&#xff08;上&#xff09; 在上篇我们讲解了切片的两个重要实现或者说是两个特征 切片是引用类型&#xff0c;会进行…

java关键字是什么?关键字有哪些?什么是常量?

1、关键字 &#xff08;1&#xff09;关键字概述&#xff1a;被java语言赋予了特定含义的单词。 &#xff08;2&#xff09;关键字特点&#xff1a; 关键字的字母全部小写&#xff1b;常用的代码编辑器&#xff0c;针对关键字有特殊的颜色标记&#xff0c;非常直观。 以IDE…

【QT+QGIS跨平台编译】之七十一:【QGIS_Analysis跨平台编译】—【qgsrastercalclexer.cpp生成】

文章目录 一、Flex二、生成来源三、构建过程一、Flex Flex (fast lexical analyser generator) 是 Lex 的另一个替代品。它经常和自由软件 Bison 语法分析器生成器 一起使用。Flex 最初由 Vern Paxson 于 1987 年用 C 语言写成。 “flex 是一个生成扫描器的工具,能够识别文本中…

机器学习之分类回归模型(决策数、随机森林)

回归分析 回归分析属于监督学习方法的一种&#xff0c;主要用于预测连续型目标变量&#xff0c;可以预测、计算趋势以及确定变量之间的关系等。 Regession Evaluation Metrics 以下是一些最流行的回归评估指标: 平均绝对误差(MAE):目标变量的预测值与实际值之间的平均绝对差…

在 windows 下安装并调试 CMake

一、前言 CMake是一个跨平台的开源工具&#xff0c;用于管理软件项目的构建过程。它不直接构建软件&#xff0c;而是生成用于特定平台或编译器的构建文件&#xff08;如Makefile或Visual Studio项目文件&#xff09;&#xff0c;然后利用这些文件来实际构建软件。 二、初次尝…

微服务架构 | 架构演进

INDEX 1 架构演进 1 架构演进 standalone 就部署一份 可用性问题&#xff1a;只有一个点&#xff0c;单点故障 全挂流量瓶颈&#xff1a; 只有一个点&#xff0c;可以支持的流量有限性能越高的服务器价格会非线性增加 功能耦合&#xff1a;协同开发困难&#xff0c;各自改一…

大数据开发-Hive介绍以及安装配置

文章目录 数据库和数据仓库的区别Hive安装配置Hive使用方式Hive日志配置 数据库和数据仓库的区别 数据库&#xff1a;传统的关系型数据库主要应用在基本的事务处理&#xff0c;比如交易&#xff0c;支持增删改查数据仓库&#xff1a;主要做一些复杂的分析操作&#xff0c;侧重…

Day34:安全开发-JavaEE应用反射机制攻击链类对象成员变量方法构造方法

目录 Java-反射-Class对象类获取 Java-反射-Field成员变量类获取 Java-反射-Method成员方法类获取 Java-反射-Constructor构造方法类获取 Java-反射-不安全命令执行&反序列化链构造 思维导图 Java知识点 功能&#xff1a;数据库操作&#xff0c;文件操作&#xff0c;…

系统安全与网络攻击

系统安全与网络攻击 Web攻击 XSS 即&#xff08;Cross Site Scripting&#xff09;中文名称为&#xff1a;跨站脚本攻击。XSS的重点不在于跨站点&#xff0c;而在于脚本的执行。 XSS的攻击原理&#xff1a;恶意攻击者在web页面中会插入一些恶意的script代码。当用户浏览该页面的…

pytorch安装记录

pytorch安装记录 1 安装anconda2 安装pycharm3 安装显卡驱动4 根据显卡驱动版本下载CUDA5 cudnn安装6 根据CUDA版本安装pytorch7 pytorch卸载 1 安装anconda 下载地址: https://www.anaconda.com/download#downloads 验证是否安装成功&#xff1a;打开cmd, 输入 conda 验证环…

基于YOLOv8的手机摄像头的自动检测系统

文章大纲 数据集网络爬虫开源数据集标注目标定义标注标准标注工具标签更换脚本自制数据集下载地址自动检测系统设计与搭建模型训练与准确率代码仓库下载地址参考文献与学习路径随着移动通信技术的飞速发展,消费者对移动终端的要求也越来越高,各厂商纷纷提出自己的特色卖点,其…

华为手机正在重回巅峰

在相对低迷的行业周期之下&#xff0c;2023年下半年智能手机行业迎来了华为的回归&#xff0c;这给本就竞争激烈的市场环境&#xff0c;带来了更大变数。 早在1月29日就有消息称&#xff0c;华为已经注册“星耀手机”品牌商标&#xff0c;定位中端手机市场&#xff0c;但相关消…

django动态表技术(根据日期,年月日)方法二

方法一&#xff1a; 第一步&#xff1a;在models创建一个类&#xff0c;里边存放数据表中需要的字段&#xff0c;如下 class TemplateModel(models.Model):NowTime models.CharField(max_length5)name models.CharFiedld(max_length5)class Meta:abstract True # 基础类设…