NoSuchMethodError報錯和Tomcat的jar包加載順序

問題

  • 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服務器生效
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章