文档章节

一个java.lang.IncompatibleClassChangeError的问题解决

zimingforever
 zimingforever
发布于 2015/08/05 17:02
字数 502
阅读 2978
收藏 0

引入一个第三方库做一个功能,依往常一样,引入对应的pom,对方的包里是有mina的,所以调用的相应的功能的时候报如下错误。

Exception in thread "pool-18-thread-1" java.lang.IncompatibleClassChangeError
	at org.apache.mina.core.filterchain.DefaultIoFilterChain.register(DefaultIoFilterChain.java:267)
	at org.apache.mina.core.filterchain.DefaultIoFilterChain.addLast(DefaultIoFilterChain.java:174)
	at org.apache.mina.core.filterchain.DefaultIoFilterChainBuilder.buildFilterChain(DefaultIoFilterChainBuilder.java:436)
	at org.apache.mina.core.polling.AbstractPollingIoProcessor.addNow(AbstractPollingIoProcessor.java:528)
	at org.apache.mina.core.polling.AbstractPollingIoProcessor.handleNewSessions(AbstractPollingIoProcessor.java:501)
	at org.apache.mina.core.polling.AbstractPollingIoProcessor.access$400(AbstractPollingIoProcessor.java:67)
	at org.apache.mina.core.polling.AbstractPollingIoProcessor$Processor.run(AbstractPollingIoProcessor.java:1116)
	at org.apache.mina.util.NamePreservingRunnable.run(NamePreservingRunnable.java:51)
	at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
	at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
	at java.lang.Thread.run(Thread.java:745)

看起来是mina中一个filter链在注册什么功能时候发生incompatible的错误。

首先怀疑是这个第三方库中的mina和我本地服务的mina冲突了,于是我再pom中找到所有的mina依赖 然后依次注释掉了。但是其实有些pom内部也会依赖的mina的,于是使用mvn的dependency tree命令查看子依赖

mvn dependency:tree >1.txt

然后依次exclusion掉对应的mina依赖。

<exclusions>
    <exclusion>
       <groupId>org.apache.mina</groupId>
       <artifactId>mina-core</artifactId>
    </exclusion>
</exclusions>

然后启动,发现还是报这个问题。然后debug到DefaultIoFilterChain的register方法。发现mina会依次注入logger和protocol。然后对应的报错是在注入logger的时候报错的。然后尝试再依次注释掉对应的log4j的依赖。不过还是有这个问题。

==========================================================================================

其实理论上这个问题一般环境下已经解决ok了。

我这边是由于其它原因造成的,分析继续:是不是我本地环境的问题?于是联系了中间件的同学,发现我们tomcat下有一个基础服务的sar包,这个sar包由于版本过低,和mina的服务冲突。于是升级该sar包(该sar包确实有对mina做更改)。问题解决,服务正常调用。

总结一下,这个问题整整坑了我一天,其实只是一个类冲突的问题,最后升级到了环境问题。这里总结一下,给后来的同学排坑用。


参考文档:http://stackoverflow.com/questions/1980452/what-causes-java-lang-incompatibleclasschangeerror


© 著作权归作者所有

zimingforever
粉丝 143
博文 266
码字总数 315040
作品 0
杭州
程序员
私信 提问
如何像程序员一样思考——解决问题的经验

如何你对编程感兴趣,你可能见过这句话: “Everyone in this country should learn to program a computer, because it teaches you to think.” — Steve Jobs 你可能还想知道,像程序员...

java知识分子
2018/09/15
0
0
【细品架构3/100】架构之问题识别

本文主要是继续研读了资深架构师王概凯Kevin执笔的《架构漫谈》系列的《架构漫谈(三):如何做好架构之识别问题》的心得感受。王概凯Kevin结合自己多年的架构经验,通过不同的视角,重新审视...

SuShine
2018/07/09
0
0
问题以及发现问题和解决问题

发现问题比解决问题更重要,如果发现了问题的所在,解决它仅仅是一个时间的问题,可能有些问题永远解决不了,但是我们最终知道它永远解决不了也算是解决了问题。问题的实质其实是一种反差,也...

晨曦之光
2012/04/10
91
0
如何做好架构之识别问题

按照之前架构的定义,做好架构首先需要做的就是识别出需要解决的问题。一般来说,如果把真正的问题找到,那么问题就已经解决了80%了。这个能力基本上就决定了架构师的水平。 那么面对问题有哪...

刘星石
2016/03/02
15
0
前沿 | 经典计算的天花板:科学家找到只有量子计算才能解决的问题

  选自QuantaMagazine   作者:Kevin Hartnett   机器之心编译   参与:Huiyuan Zhuo、刘晓坤      在量子计算机研究的早期,计算机科学家提出了一个问题,他们知道这个问题的答...

机器之心
2018/07/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Java agentlib参数分析

Java agentlib参数分析 再用intellij idea进行远程调试的时候,具体的配置选项如下: 标红的一行显示了远程调试需要添加的虚拟机参数。这个参数到底有什么意义? 我在命令行输入java命令,输...

Mr_Tea伯奕
32分钟前
1
0
四种软件架构演进史,程序员会一种就很牛了!

如果一个软件开发人员,不了解软件架构的演进,会制约技术的选型和开发人员的生存、晋升空间。这里我列举了目前主要的四种软件架构以及他们的优缺点,希望能够帮助软件开发人员拓展知识面。 ...

我最喜欢三大框架
37分钟前
3
0
如何做高可用的架构设计?

定义目标 既然我们的目标是做到高可用,那么我们就有必要先明确清楚高可用的含义,并通过拆解目标,让目标可以被量化。按照我的理解,可以将目标按照以下三条进行拆解: 1. 保持业务高稳定性...

别打我会飞
37分钟前
2
0
《错误的行为》的读后感优秀范文4000字

《错误的行为》的读后感优秀范文4000字: 第一章经济人和非理性人。本书中的经纪人是指经济学家经济模式中虚拟的理想人物,非理性人是指现实生活中实实在在存在的人,与经济人相对应的人。 ...

原创小博客
48分钟前
3
0
将二叉搜索树转换成一个排序的双向链表。要求不能创建任何新的结点,只能调整树中结点指针的指向

作者图解释很好 https://blog.csdn.net/yanxiaolx/article/details/52073221

南桥北木
54分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部