问题
Java 项目,使用maven 管理jar 包,war 包部署,Tomcat 服务器- 某个方法在底层包里有,但是本子系统需要对方法改动,就把类copy过来,同路径,修改了方法,加了参数。
- 这个时候,2个jar包里,都有这个工具类,但是2个类里的某一个方法不同,参数个数不同。
- 本地运行调试没问题,在一台centos7上部署运行也没问题,但是轮到我自己实施部署项目,发现方法执行时报错:
java.lang.NoSuchMethodError
解决
- 根据报错信息,可以明显知道,就是方法找不到,加载时读取了原有的jar包里的类和方法,没有读取新加的类和方法。
- 不同环境,有的可以,有的不可以。最终对比和测试后发现,和服务器操作系统以及Tomcat版本有关。
Windows 上是可以的,Tomcat7 也可以,但是centos7 + Tomcat 8.5 就会报错。 - tomcat8之前,按照jar包字母顺序加载,寻找类和方法
- tomcat8及之后版本,不再按照字母顺序加载,在不同服务器上受到影响,加载的顺序可以能不一致
- 针对Tomcat8以及以上版本,可以通过修改Tomcat服务器里
conf 下的context.xml ,来指定优先加载部分需要的jar包。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <Context> <!-- Default set of monitored resources. If one of these changes, the --> <!-- web application will be reloaded. --> <WatchedResource>WEB-INF/web.xml</WatchedResource> <WatchedResource>${catalina.base}/conf/web.xml</WatchedResource> <!-- Uncomment this to disable session persistence across Tomcat restarts --> <!-- <Manager pathname="" /> --> <Resources> <PreResources className="org.apache.catalina.webresources.FileResourceSet" base="/home/webroot/ls-static-web/WEB-INF/lib/ls-aacustom-common-1.0-SNAPSHOT.jar" webAppMount="/WEB-INF/lib/ls-aacustom-common-1.0-SNAPSHOT.jar" /> <PreResources className="org.apache.catalina.webresources.FileResourceSet" base="/home/webroot/ls-static-web/WEB-INF/lib/ls-aacustom-static-1.0-SNAPSHOT.jar" webAppMount="/WEB-INF/lib/ls-aacustom-static-1.0-SNAPSHOT.jar" /> </Resources> </Context> |
- 配置好后,重启Tomcat服务器生效