与第三方对接时,引入了第三方jar,本地Tomcat正常启动,线上Tomcat启动失败,不排除是因为Tomcat版本问题导致的

问题说明

当项目中存在相同的类,但具体的方法不同时,classloader加载了一个类之后,不会再加载第二个相同的类,但是你要用的类正好是那个没有被加载的类,此时,直接删了那个不用的类?可以解决,但最好是不删,万一那个类也是需要的呢,毕竟,在协同开发中,不要轻易的删除小伙伴的东西。还有,如果冲突的那个类在jar包中呢,而jar包中还有其他有用的类,这个时候,你只能告诉虚拟机(或者是说web容器,这里就是tomcat)优先加载哪个jar包。

解决方法

1.在${CATALINA_HOME}/conf/context.xml全局配置文件中配置(有可能会影响其他的项目,不推荐)

1
2
3
4
<Resources>
<PreResources className="org.apache.catalina.webresources.FileResourceSet"
base="${catalina.base}/webapps/你的项目名称/WEB-INF/lib/提到前面来的冲突jar包名.jar" webAppMount="/WEB-INF/lib/提到前面来的冲突jar包名.jar" />
</Resources>

2.在项目的META-INF/context.xml中配置(推荐)

1
2
3
4
5
6
7
8
9
<?xml version="1.0" encoding="UTF-8"?>

<Context>
<Resources>
<PreResources base="xxx\WEB-INF\lib\xxx.jar"
className="org.apache.catalina.webresources.JarResourceSet"
webAppMount="/WEB-INF/classes"/>
</Resources>
</Context>

参考文档

Tomcat配置优先加载某个jar包,解决相同类名冲突

Tomcat同一目录下jar包加载顺序问题