ClassNotFoundException: org.elasticsearch.client.Cancellable 和nosuchfielderror:lucene_8_0_0

文章讲述了在整合SpringCloud和Elasticsearch7.6.2时遇到的两个主要问题:ClassNotFoundException和NoSuchFieldError。作者分析了问题的原因,发现是SpringBoot内置的Elasticsearch版本与添加的依赖版本不一致,以及Lucene版本不匹配。解决方案包括在pom.xml中添加dependencyManagement来统一版本,删除旧的jar包,以及确保使用的Lucene版本与Elasticsearch版本兼容。经过这些步骤,作者成功地解决了问题并进行了测试。
摘要由CSDN通过智能技术生成

一天时间都在解决这个问题。做一下笔记吧

在做springcloud整合es7.6.2出现了一些问题。

两个主要的报错:

  1. 先解决第一个:ClassNotFoundException: org.elasticsearch.client.Cancellable

我的maven配置


        <dependency>
            <groupId>org.elasticsearch.client</groupId>
            <artifactId>elasticsearch-rest-high-level-client</artifactId>
            <version>7.6.2</version>
        </dependency>

配置类也配置了

@Bean
    public RestHighLevelClient esRestClient(){
        RestClientBuilder builder = null;
        builder = RestClient.builder(new HttpHost("127.0.0.1", 9200, "http"));
        RestHighLevelClient restHighLevelClient = new RestHighLevelClient(builder);
        return restHighLevelClient;
    }

然后在启动时就报了以下错误

看了一下相关的博客,得出是版本依赖不一致的问题。

为什么版本不一致,原来springbootd(我的版本是2.2.2)的依赖内置了elasticsearch,所以导致了版本不一致的问题。

解决版本不一致的问题:

    <properties>
        <java.version>1.8</java.version>
        <elasticsearch.version>7.6.2</elasticsearch.version>
    </properties>

但是我这么设置,不生效

所以我改了使用以下方式,设置相同版本的依赖:

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.elasticsearch.client</groupId>
                <artifactId>elasticsearch-rest-client</artifactId>
                <version>7.6.2</version>
            </dependency>
            <dependency>
                <groupId>org.elasticsearch</groupId>
                <artifactId>elasticsearch</artifactId>
                <version>7.6.2</version>
            </dependency>
        </dependencies>
    </dependencyManagement>

效果就出来了

前提一定要删除旧的jar包,不然还是引用原来的版本!

不删除就会出现这种情况

测试数据:

        @Resource
    private RestHighLevelClient restHighLevelClient;

    @Test
    public void indexDataTest() throws IOException {
        //新建一个索引
        IndexRequest indexRequest = new IndexRequest("users");
        //数据id
        indexRequest.id("1");
        //通过对象转json方式存储到es
        User user = new User();
        user.setUserName("zhangsan");
        user.setGender("男");
        user.setAge(22);
        //转json
        String jsonString = JSON.toJSONString(user);
        indexRequest.source(jsonString, XContentType.JSON);  //要保存的内容

        //执行操作
        IndexResponse index = restHighLevelClient.index(indexRequest, RequestOptions.DEFAULT);
        //输入结果
        System.out.println(index);
    }

测试成功:

  1. 解决:java.lang.NoSuchFieldError: LUCENE_8_0_0

但是通过接口的方式保存数据就会出现这个问题:

排查原因:

打开Version.java,可以看到,我当前的elastic版本是7.6.2,那lucene的版本也应该对应的是8.4.0,但是我用Ctrl +鼠标右键,却没有进入到找到对应的版本。而只能定位到7.7.2的版本

最高支持到7.7.2的版本

最后打开 lucene-core-8.4.0.jar > org.apache.lucene.util> Version.java 这个类,才发现这个包下才有支持7.6.2版本的 lucene版本

原因: 应该是elastic调用了之前的 6.8.5版本的jar包,所以才没有找到对应的版本。

解决方案:把 lucene-core7.7.2 的jar包删除

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值