SpringBoot 整合elasticsearch

本文介绍了如何在SpringBoot应用中不使用spring-data-elasticsearch,而是直接通过elasticsearch-rest-high-level-client与Elasticsearch进行整合。强调了客户端版本需与ES集群版本匹配,并提供了引入依赖、配置类编写及操作工具类的步骤。同时,针对大数据量查询,提到了scroll游标和slice分片查询的方法。
摘要由CSDN通过智能技术生成

1、前言

es的客户端连接有几种方式:

  • REST:

执行REST风格的HTTP请求。7.x版本开始弃用TransportClient,并用高级rest客户端替代。

  • TransportClient:

作为外部访问者,请求ES的集群。5.x前主要的连接方式,作为rest客户端的过渡版本。

  • NodeClient

作为ES集群的一个节点,它是ES中的一环,其他的节点对它是感知的。通常不建议使用。

springBoot本身提供了spring-data-elasticsearch来连接es,但是由于es版本更新较快,目前最新版的spring-data-elasticsearch也只有3.1.10.RELEASE,对应es版本是6.4.3,而且提供的ElasticsearchTemplate类(当然spring-data-elasticsearch也提供了elasticsearch-rest-client包,但版本也是6.4.3,这个版本的api不全,而且跟我们直接引用rest包一样需要自己另写方法使用),实际上还是使用TransportClient或NodeClient来进行操作,因此不是很建议使用spring-data-elasticsearch,更建议直接使用elasticsearch-rest-high-level-client,以下也是基于elasticsearch-rest-high-level-client来操作es,注意es客户端的版本需要跟es集群版本对应,我这里是使用7.3.1

2、引入依赖

        <!--注意:如果使用了parent那么需要在此定义es版本号,因为spring-boot-start-parent中已经定义了es相关依赖的版本号 
		,high-level-client中的部分依赖会被覆盖成低版本的,导出出现莫名其妙的错误 -->
	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.elasticsearch.client</groupId>
				<artifactId>elasticsearch-rest-high-level-client</artifactId>
				<version>7.3.1</version>
			</dependency>
			<!-- https://mvnrepository.com/artifact/org.elasticsearch/elasticsearch -->
			<dependency>
				<groupId>org.elasticsearch</groupId>
				<artifactId>elasticsearch</artifactId>
				<version>7.3.1</version>
			</dependency>
			<!--&lt;!&ndash; https://mvnrepository.com/artifact/org.elasticsearch.client/elasticsearch-rest-client 
				&ndash;&gt; -->
			<dependency>
				<groupId>org.elasticsearch.client</groupId>
				<artifactId>elasticsearch-rest-client</artifactId>
				<version>7.3.1</version>
			</dependency>
		</dependencies>
	</dependencyManagement>

<dependencies>
        <dependency>
			<groupId>org.elasticsearch.client</groupId>
			<artifactId>elasticsearch-rest-high-level-client</artifactId>
		</dependency>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值