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版本对应关系的主要内容,如果未能解决你的问题,请参考以下文章

005_elasticsearch的数据导入导出

ElasticSearch_05_ES聚合aggregations运算

ElasticSearch_07_ES聚合aggregations运算

ElasticSearch_07_ES聚合aggregations运算

ElasticSearch_07_ES聚合aggregations运算

ElasticSearch_03_ES的基本筛选条件