maven-jar包冲突影响。查看堆栈信息可以排查相关冲突问题。
可能在测试环境无法发现,一上生产就出现各种冲突报告。最简单的办法就是仔细仔细排查两个环境具体的区别。绝大部分原因是因为系统文件盘的变化?
Java应用程序因某种因素,加载不到正确的类而导致其行为跟预期不一致。
- 同一个Jar包出现了多个不同版本
- 同一个类出现在多个不同Jar包中
Jar包的加载顺序;Jar包所处加载路径的不同,就决定了它的加载顺序的不同。
文件系统的文件加载顺序:数据盘和系统盘的变化也会影响到加载顺序。
java.lang.ClassNotFoundException ,即java类找不到。
java.lang.NoSuchMethodError ,即找不到特定方法,第一类冲突和第二类冲突都可能导致该问题——加载的类不正确。
问题排查和解决
- 如果有异常堆栈信息,根据错误信息即可定位导致冲突的类名,然后在eclipse中 CTRL+SHIFT+T 或者在idea中 CTRL+N 就可发现该类存在于多个依赖Jar包中
- 若步骤1无法定位冲突的类来自哪个Jar包,可在应用程序启动时加上JVM参数 -verbose:class 或者 -XX:+TraceClassLoading ,日志里会打印出每个类的加载信息,如来自哪个Jar包。定位了冲突类的Jar包之后,通过 mvn dependency:tree -Dverbose -Dincludes= : 查看是哪些地方引入的Jar包的这个版本。确定Jar包来源之后,
2.1 如果是第一类《同一个Jar包出现了多个不同版本》Jar包冲突,则可用排除不需要的Jar包版本或者在依赖管理中申明版本;
2.2 若是第二类《同一个类出现在多个不同Jar包中》Jar包冲突,如果可排除,则用排掉不需要的那个Jar包,若不能排,则需考虑Jar包的升级或换个别的Jar包。当然,除了这些方法,还可以从类加载器的角度来解决该问题。