包冲突问题定位思路
近期遇见了包冲突问题导致服务启动后功能失效的问题,尝试着解决了一下,具体的思路总结如下。
本节重点
正常包冲突会导致服务启动失败且日志落盘到error.log中,但是有一些特殊情况,服务仍然正常启动,且日志以warning打到info.log中,举例:spring的applicationContext就有这种情况。
工具安装
工欲善其事,必先利其事。首先安装IDEA的包冲突识别插件。
步骤一:
步骤二:
点开pom文件。
步骤三:
点开dependency analyzer。
解决冲突包
启动日志中,一般会打启动失败的原因,如果有冲突会打异常。
一般为:
NoClassDefFoundError
NoSuchMethodError / NoSuchFieldError
ClassNotFoundException
InvalidClassException:local class incompatible
LinkageError
找到对应的异常调用栈,在对应的代码里搜索其所属包及包版本,在dependency analyzer中搜索冲突版本。
在pom.xml中excution掉objenesis这个包
大体思路是在pom.xml中强制指定冲突包的版本,并排出高版本或者低版本的包。
总结
包冲突问题大体表现都是启动失败,或者启动后服务不可用,遇见这种问题不要慌,首要的就是分析日志(所有的日志,不管是error还是info),在日志中找寻初始化信息,并对应解决。