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

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

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

一、命令式Rest客户端

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

java 复制代码
@Configuration
public class MyClientConfig extends ElasticsearchConfiguration {

	@Override
	public ClientConfiguration clientConfiguration() {
		return ClientConfiguration.builder()           --------1
			.connectedTo("localhost:9200")
			.build();
	}
}

1. 有关构建器方法的详细说明,请参见章节三客户端配置

ElasticsearchConfiguration类允许通过重写例如jsonpMapper()或transportOptions()方法进行进一步配置。

然后可以将以下beans注入到其他Spring组件中:

java 复制代码
ElasticsearchOperations operations;      --------1

@Autowired
ElasticsearchClient elasticsearchClient; --------2

@Autowired
RestClient restClient;                   --------3

@Autowired
JsonpMapper jsonpMapper;                 --------4

1. ElasticsearchOperations的一种实现
2. 使用的co.elastic.clients.elasticsearch.ElasticsearchClient。
3. Elasticsearch库中的低级RestClient
4. Elasticsearch传输的JsonpMapper用户

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

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

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

java 复制代码
@Configuration
public class MyClientConfig extends ReactiveElasticsearchConfiguration {

	@Override
	public ClientConfiguration clientConfiguration() {
		return ClientConfiguration.builder()           --------1
			.connectedTo("localhost:9200")
			.build();
	}
}

1. 有关构建器方法的详细说明,请参见章节三客户端配置

ReactiveElasticsearchConfiguration类允许通过重写例如jsonpMapper()或transportOptions()方法进行进一步配置。

然后可以将以下bean注入到其他Spring组件中:

java 复制代码
@Autowired
ReactiveElasticsearchOperations operations;      --------1

@Autowired
ReactiveElasticsearchClient elasticsearchClient; --------2

@Autowired
RestClient restClient;                           --------3

@Autowired
JsonpMapper jsonpMapper;                         --------4

1. 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:客户端配置

java 复制代码
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或启用SSL。
3. 可选地启用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配置:

四、客户端日志

相关推荐
Lansonli11 分钟前
大数据Spark(七十二):Transformation转换算子repartition和coalesce使用案例
大数据·分布式·spark
chde2Wang12 分钟前
hbase启动报错-keeperErrorCode
大数据·数据库·hbase
清平乐的技术专栏15 分钟前
HBase Shell常用命令
大数据·数据库·hbase
数字冰雹1 小时前
重塑城市公共安全管理的“智慧之眼”
java·大数据·数据库
August_._1 小时前
【MySQL】触发器、日志、锁机制 深度解析
java·大数据·数据库·人工智能·后端·mysql·青少年编程
B站_计算机毕业设计之家2 小时前
大数据YOLOv8无人机目标检测跟踪识别系统 深度学习 PySide界面设计 大数据 ✅
大数据·python·深度学习·信息可视化·数据挖掘·数据分析·flask
AORO20253 小时前
遨游科普:三防平板是指哪三防?有哪些应用场景?
大数据·网络·5g·智能手机·电脑·信息与通信
橙色云-智橙协同研发3 小时前
【PLM实施专家宝典】离散制造企业ECO管理优化方案:构建自动化、零错误的变更引擎
大数据·云原生·解决方案·数字化转型·plm·eco·云plm
星光一影4 小时前
基于SpringBoot智慧社区系统/乡村振兴系统/大数据与人工智能平台
大数据·spring boot·后端·mysql·elasticsearch·vue
e6zzseo7 小时前
独立站的优势和劣势和运营技巧
大数据·人工智能