NoSuchMethodError报错和Tomcat的jar包加载顺序

5 篇文章 0 订阅

问题

  • 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包。
<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服务器生效
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

坚持是一种态度

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值