时间:2021-05-19
最近一个项目测试的时候,需要进行多个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的依赖。 具体如下:
<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。 解决!
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
用户卸载人脸识别后,开机报错。(如图)原因分析:由于卸载异常,导致残留启动命令,但是运行文件已经卸载掉。解决方案:1、运行autoruns软件,在everyth
问题怎样捕获代码中的所有异常?解决方案想要捕获所有的异常,可以直接捕获Exception即可:try:...exceptExceptionase:...log(
目录1.count数据丢失解决方案2.distinct数据丢失3.select数据丢失解决方案4.导致空指针异常5.增加了查询难度总结正式开始之前,我们先来看下
解决方案如下,其它框架雷同。源代码(/system/libraries/upload.php199line)$this->file_type=preg_repl
Fatal:thePostfixmailsystemisalreadyrunning的解决方案【问题情境】当启动postfix服务时出现如下错误提示:#serv