ElasticSearch_10_ES和SpringBoot版本对应关系
Posted 毛奇志
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ElasticSearch_10_ES和SpringBoot版本对应关系相关的知识,希望对你有一定的参考价值。
问题描述
记录开发中遇到的问题:
报错:Elasticsearch exception [type=illegal_argument_exception, reason=request [/index索引名/_search] contain
原因分析:
spring 2.4.5版本集成ES时,默认集成的是7.9的ES。
我环境搭建的ES是6.8的,导致两个版本不匹配,报上述错误。下方是spring和ES的对应版本,建议大家做好版本匹配。
第二列SpringDataElasticSearch是pom依赖的版本;
第三列ElasticSearch是linux上安装的es中间件版本;
第五列SpringBoot是pom依赖的版本.
解决方案
下面讲一下版本号不匹配时的解决方案:
(更改前)调整springboot集成ES的配置,这是我版本不兼容时的pom引用配置
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-elasticsearch</artifactId>
</dependency>
<dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>elasticsearch-rest-high-level-client</artifactId>
<version>7.9.3</version>
</dependency>
(更改后)由于spring-boot-starter-data-elasticsearch会依据springboot的版本号自动匹配响应的ES,所以我去除了该引用,改成下方配置(没办法做到两个环境版本兼容的情况,就更改springboot集成的ES版本,我这里是降低了ES版本,暂时没发现什么问题,仅个别方法使用差异,影响不大):
<dependency>
<groupId>org.elasticsearch</groupId>
<artifactId>elasticsearch</artifactId>
<version>6.8.22</version>
</dependency>
<dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>elasticsearch-rest-high-level-client</artifactId>
<version>6.8.22</version>
</dependency>
ES用法差异:
高版本ES在获取请求时,可以不录入TYPE参数
GetRequest getRequest = new GetRequest(indexName, id);
换成低版本后,要录入TYPE
GetRequest getRequest = new GetRequest(indexName, TYPE, id);
以上是关于ElasticSearch_10_ES和SpringBoot版本对应关系的主要内容,如果未能解决你的问题,请参考以下文章
ElasticSearch_05_ES聚合aggregations运算
ElasticSearch_07_ES聚合aggregations运算
ElasticSearch_07_ES聚合aggregations运算