記一次NoSuchMethodError問(wèn)題的排查

現(xiàn)場(chǎng)描述

在升級(jí)了某組件后,應(yīng)用啟動(dòng)時(shí)拋如下異常尿庐,導(dǎo)致啟動(dòng)失敗:

2017-07-13 15:18:53.388 [C6686525] [] [] ERROR c.y.t.m.a.ServiceAspect - NoSuchMethodError
 Method:public com.youzan.api.common.response.PlainResult com.youzan.trade.manage.es.service.impl.SearchServiceImpl.getSearchResult(com.youzan.trade.man
age.api.param.SearchQueryParam)
 Arguments:{
}
java.lang.NoSuchMethodError: com.youzan.nsq.client.entity.NSQConfig.setLookupAddresses(Ljava/lang/String;)Lcom/youzan/nsq/client/entity/NSQConfig;
        at com.youzan.trade.metrics.NsqReporter.connect(NsqReporter.java:41) ~[trade-metrics-core-1.0-RELEASE.jar:na]
        at com.youzan.trade.metrics.NsqReporter.<init>(NsqReporter.java:36) ~[trade-metrics-core-1.0-RELEASE.jar:na]
        at com.youzan.trade.metrics.Registry.<init>(Registry.java:54) ~[trade-metrics-core-1.0-RELEASE.jar:na]

過(guò)程分析

工程A引入了組件呢堰、以及均依賴公司內(nèi)二次開(kāi)發(fā)NSQ-client抄瑟,為采集應(yīng)用,均調(diào)用了NSQ-Client中NSQCongfig的同名方法暮胧,即上日志中提示NoSuchMethodError的方法:

config = new NSQConfig();
config.setLookupAddresses(lookUpAddress);

排查過(guò)程中锐借,發(fā)現(xiàn)組件依賴的NSQ-Client版本為:2.2.20170424-RELEASE 依賴的NSQ-Client版本為2.3.20170424-RELEASE 粗對(duì)比兩者的函數(shù)簽名,方法名往衷,入?yún)⒍家恢鲁琛0偎翰坏闷浣恪:?組內(nèi)同學(xué)阿奎 debug的時(shí)候發(fā)現(xiàn)席舍,兩個(gè)版本的方法返回值不同布轿,當(dāng)時(shí)恍然大悟。自己在問(wèn)題排查是并沒(méi)有注意到返回值信息,因?yàn)樵趦蓚€(gè)lib中調(diào)用時(shí)均未獲取返回值汰扭,但是實(shí)際在編譯過(guò)程中稠肘,已經(jīng)將返回值信息編譯到class文件中。
NSQ-Client兩個(gè)版本相同類中對(duì)應(yīng)方法簽名分別為:

#2.3.20170424-RELEASE
public NSQConfig setLookupAddresses(final String lookupAddresses) 
#2.2.20170424-RELEASE
public void setLookupAddresses(String lookupAddresses) 

導(dǎo)致分別依賴兩個(gè)版本NSQ-Client且均調(diào)用此方法的lib無(wú)法共存萝毛。

舉一反三

public class NSQPublisher{
    private Client c = new Client();
    public void doSome(){
        c.command();
    }
    public static void main(String[] args){
        NSQPublisher publisher = new NSQPublisher();
        publisher.doSome();
    }
}
public class Client{
    public void command(){
        System.out.println("Do command");
    }
}

定義兩個(gè)類项阴,編譯執(zhí)行,正常輸出:

?  Desktop javac -cp . Client.java
?  Desktop javac -cp . NSQPublisher.java
?  Desktop java NSQPublisher
Do command

此時(shí)將Client中的command調(diào)整為返回boolean值笆包,再編譯執(zhí)行环揽,問(wèn)題重現(xiàn):

?  Desktop javac -cp . Client.java
?  Desktop java NSQPublisher
Exception in thread "main" java.lang.NoSuchMethodError: Client.command()V
    at NSQPublisher.doSome(NSQPublisher.java:5)
    at NSQPublisher.main(NSQPublisher.java:10)

直接查看反編譯后信息:

?  Desktop javap -c NSQPublisher.class
Compiled from "NSQPublisher.java"
public class NSQPublisher {
  public NSQPublisher();
    Code:
       0: aload_0
       1: invokespecial #1                  // Method java/lang/Object."<init>":()V
       4: aload_0
       5: new           #2                  // class Client
       8: dup
       9: invokespecial #3                  // Method Client."<init>":()V
      12: putfield      #4                  // Field c:LClient;
      15: return
  public void doSome();
    Code:
       0: aload_0
       1: getfield      #4                  // Field c:LClient;
       4: invokevirtual #5                  // Method Client.command:()V
       7: return
  public static void main(java.lang.String[]);
    Code:
       0: new           #6                  // class NSQPublisher
       3: dup
       4: invokespecial #7                  // Method "<init>":()V
       7: astore_1
       8: aload_1
       9: invokevirtual #8                  // Method doSome:()V
      12: return
}

昭然若揭。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末庵佣,一起剝皮案震驚了整個(gè)濱河市歉胶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌巴粪,老刑警劉巖通今,帶你破解...
    沈念sama閱讀 222,681評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異肛根,居然都是意外死亡辫塌,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,205評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)晶通,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)璃氢,“玉大人哟玷,你說(shuō)我怎么就攤上這事狮辽。” “怎么了巢寡?”我有些...
    開(kāi)封第一講書(shū)人閱讀 169,421評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵喉脖,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我抑月,道長(zhǎng)树叽,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 60,114評(píng)論 1 300
  • 正文 為了忘掉前任谦絮,我火速辦了婚禮题诵,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘层皱。我一直安慰自己性锭,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,116評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布叫胖。 她就那樣靜靜地躺著草冈,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上怎棱,一...
    開(kāi)封第一講書(shū)人閱讀 52,713評(píng)論 1 312
  • 那天哩俭,我揣著相機(jī)與錄音,去河邊找鬼拳恋。 笑死凡资,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的谬运。 我是一名探鬼主播讳苦,決...
    沈念sama閱讀 41,170評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼吩谦!你這毒婦竟也來(lái)了鸳谜?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 40,116評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤式廷,失蹤者是張志新(化名)和其女友劉穎咐扭,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體滑废,經(jīng)...
    沈念sama閱讀 46,651評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蝗肪,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,714評(píng)論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了蠕趁。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片薛闪。...
    茶點(diǎn)故事閱讀 40,865評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖俺陋,靈堂內(nèi)的尸體忽然破棺而出豁延,到底是詐尸還是另有隱情,我是刑警寧澤腊状,帶...
    沈念sama閱讀 36,527評(píng)論 5 351
  • 正文 年R本政府宣布诱咏,位于F島的核電站,受9級(jí)特大地震影響缴挖,放射性物質(zhì)發(fā)生泄漏袋狞。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,211評(píng)論 3 336
  • 文/蒙蒙 一映屋、第九天 我趴在偏房一處隱蔽的房頂上張望苟鸯。 院中可真熱鬧,春花似錦棚点、人聲如沸早处。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,699評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)陕赃。三九已至卵蛉,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間么库,已是汗流浹背傻丝。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,814評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留诉儒,地道東北人葡缰。 一個(gè)月前我還...
    沈念sama閱讀 49,299評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像忱反,于是被迫代替她去往敵國(guó)和親泛释。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,870評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容