• 记一次netty版本冲突,报java.lang.NoSuchMethodError: io.netty.util.internal.ObjectUtil.checkPositive的问题


    elasticsearch 5.6中使用TransportClient初始化抛异常

    在引入elasticsearch5.6的transportclient包中,会引入netty进行通信。

    <!-- transport客户端 -->
    <dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>transport</artifactId>
    <version>5.6.1</version>
    <exclusions>
    <exclusion>
    <groupId>commons-logging</groupId>
    <artifactId>commons-logging</artifactId>
    </exclusion>
    </exclusions>
    </dependency>

    由于项目中会用到rocketmq,rocketmq也会自带有netty

    <dependency>
    <groupId>org.apache.rocketmq</groupId>
    <artifactId>rocketmq-client</artifactId>
    <version>4.0.0-incubating</version>
    </dependency>

    用jetty启动没问题,但用tomcat报错:java.lang.NoSuchMethodError: io.netty.util.internal.ObjectUtil.checkPositive

    看来tomcat处理包冲突没有jetty好

    可以在项目pom文件所在目录,通过mvn dependency:tree 命令,查看包之间的依赖,通过查看包中的方法,发现rocketmq自带的netty包确实没有此方法,es中的nettty版本

    低于rocketmq中的netty版本。

    注意:mvn dependency:tree -Dverbose -Dincludes=asm:asm 类似的命令可以找到重复的jar包引用

    解决办法:

    1.在pom中直接引用netty4.13

             <dependency>
                <groupId>io.netty</groupId>
                <artifactId>netty-all</artifactId>
                <version>4.1.13.Final</version>
            </dependency>

    经过引入上面的jar,冲突解决。

    2.在初始化transportClient方法前添加

    // 设置环境变量,解决Es的netty与Netty服务本身不兼容问题
    System.setProperty("es.set.netty.runtime.available.processors", "false");

    第二种方法没试,但应该行的通。

    以上是问题和解决方案。

    ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

     ps:后来在初始化transportClient过程中,报错:

    java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]

    java.lang.IllegalStateException: availableProcessors is already set to [4], rejecting [4]
    at io.netty.util.NettyRuntime$AvailableProcessorsHolder.setAvailableProcessors(NettyRuntime.java:51)
    at io.netty.util.NettyRuntime.setAvailableProcessors(NettyRuntime.java:87)
    at org.elasticsearch.transport.netty4.Netty4Utils.setAvailableProcessors(Netty4Utils.java:87)
    at org.elasticsearch.transport.netty4.Netty4Transport.<init>(Netty4Transport.java:115)
    at org.elasticsearch.transport.Netty4Plugin.lambda$getTransports$0(Netty4Plugin.java:84)
    at org.elasticsearch.client.transport.TransportClient.buildTemplate(TransportClient.java:176)
    at org.elasticsearch.client.transport.TransportClient.<init>(TransportClient.java:262)
    at org.elasticsearch.transport.client.PreBuiltTransportClient.<init>(PreBuiltTransportClient.java:128)

    解决办法:

    在初始化之前加上System.setProperty("es.set.netty.runtime.available.processors", "false");

    最后问题解决。

  • 相关阅读:
    【论文阅读-Embedding】《GloVe: Global Vectors for Word Representation》
    机器学习的问题总结
    预算平滑
    ML基础番外篇-距离度量
    vim配置使用
    强化学习 Note
    强化学习(David Silver)9:探索与利用
    强化学习(David Silver)8:集成学习和计划
    强化学习(David Silver)7:策略梯度算法
    数学基础01-最优化(梯度下降法、牛顿法、拟牛顿法等)
  • 原文地址:https://www.cnblogs.com/tanglc/p/9381280.html
Copyright © 2020-2023  润新知