最近一个项目测试的时候,需要进行多个 tomcat 集群测试。 我本地用了一个新的 tomcat , 然后把项目打好的 war 包扔到 tomcat 里面进行运行。 启动时出现一个异常: java.io.ioexception: invalid constant type: 15 。
项目启动环境: jdk1.8 、 tomcat8
网上查阅资料,说是引用 dubbo 2.8 版本时,自动引用了 javassist 3.15.0 版本。 导致和 jdk 的 javassist 冲突。 查看 maven 的 pom.xml 文件,有引入 javassist 3.21.0 版本。 但是并没有3.15.0版本。
解决步骤:
一、输出maven依赖的树,并输出日志到指定文件
然后在项目的 pom.xml 文件目录,打开 cmd 环境, 执行命令 mvn dependency:tree>2.txt
二、查看2.txt文件,看到项目所有的jar的依赖树。
里面就包括了 dubbo 里面引用了 javassist 3.15.0 具体操作如下图:
然后就到依赖 dubbo 的 maven 配置那里,排除 javassist 的依赖。 具体如下:
1 2 3 4 5 6 7 8 |
<dependency> <groupid>com.alibaba</groupid> <artifactid>dubbo</artifactid> <version> 2.8 . 4 </version> <exclusions> <exclusion><artifactid>javassist</artifactid><groupid>org.javassist</groupid></exclusion> </exclusions> </dependency> |
这里大家自己的格式是什么样的就自己格式化一下。然后重新编译,更新下 maven 。 问题解决。(其他 jar 依赖冲突的问题也可以这样分析解决)
如果这样配置了还没解决。去看下2.txt文件还有没有其他关于 javassist 的依赖。一并去除。 另外就是找到你所依赖的项目的本地仓库,找到依赖项目的版本,清除,重新 install 。 解决!
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
查看更多关于启动异常invalid constant type:15的解决方案的详细内容...