利用Arthas定位線(xiàn)上問(wèn)題實(shí)例-創(chuàng)新互聯(lián)

前言

Arthas是一個(gè)類(lèi)似于Btrace的JVM在線(xiàn)調(diào)試分析工具,具體可參考我之前寫(xiě)的一篇博客:利用JVM在線(xiàn)調(diào)試工具排查線(xiàn)上問(wèn)題。本文分享筆者剛遇到的一個(gè)問(wèn)題,雖然不復(fù)雜,但是很典型。

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、成都微信小程序、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了那曲免費(fèi)建站歡迎大家使用!

問(wèn)題與分析過(guò)程

昨天上線(xiàn)遇到一個(gè)問(wèn)題,交易后給大數(shù)據(jù)平臺(tái)異步送數(shù),但是他們說(shuō)沒(méi)收到數(shù)據(jù),因?yàn)槲覀儧](méi)有打日志,所以沒(méi)有直接的證據(jù)證明是他們的問(wèn)題而不是我們的問(wèn)題。

送數(shù)的原理大致如下,就是交易主線(xiàn)程把數(shù)據(jù)放到隊(duì)列里,然后異步線(xiàn)程從隊(duì)列里把數(shù)據(jù)取出來(lái),發(fā)送到后臺(tái)。

隊(duì)列:
BlockingQueue<Message> queue = new BlockingQueue();

同步線(xiàn)程:
void sendMsg(Message msg) {
   queue.offer(msg);
}
異步線(xiàn)程:
void consume() {
   Message msg = queue.take();
   while(msg != null) {
       HttpClient.post(msg);
       msg = queue.take();
   }
}

具體送數(shù)的代碼如下( 加了行數(shù)):

38  public void consume(Map msg) {
39        HttpClient httpClient = new HttpClient(cm);
40        PostMethod method = new PostMethod(uri);
41        method.addRequestHeader("context-type", "application/x-www-form-urlencoded");
42        JSONObject json = new JSONObject(msg);
43       NameValuePair[] params = new NameValuePair[2];
44       params[0] = new NameValuePair("topic", topic);
45       params[1] = new NameValuePair("value", json.toJSONString());
46       //System.out.println(msg.toString());
47       logger.info("BigDataHttp Send Json:" + json.toJSONString());
48       method.addParameters(params);
49      try {
50
51         httpClient.executeMethod(method);
52         if(method.getStatusCode() == 200) {
53              logger.info("BigDataHttp response(Success):"+ method.getResponseBodyAsString());
54         } else {
55              logger.info("BigDataHttp Response(error):" + method.getResponseBodyAsString());
56         }
57     } catch(Exception e) {
58         logger.error(e.getMessage(), e);
59     } finally {
60         method.releaseConnection();
61     }
62  }

在日志里沒(méi)有發(fā)現(xiàn)try里的異常,而比較遺憾的是,我們的日志雖然開(kāi)了info級(jí)別,但是因?yàn)槿罩玖刻?,所以只開(kāi)了交易上送和下發(fā)報(bào)文的日志,其他的日志都關(guān)了。

現(xiàn)在日志級(jí)別沒(méi)法調(diào),有沒(méi)有辦法能確定,請(qǐng)求返回了200,還是其他值呢?

可以用在線(xiàn)調(diào)試工具Arthas,我們使用Arthas的trace功能,查看這個(gè)類(lèi)執(zhí)行的詳細(xì)步驟。

首先連接上這個(gè)JVM進(jìn)程,pid為進(jìn)程號(hào)。

java -jar arthas-boot.jar pid

然后執(zhí)行命令

trace xxx.util.bigDataUtil.BigDataHttpConsumer consume

這條命令的左右就是,追蹤xxx.util.bigDataUtil.BigDataHttpConsumer類(lèi)里consume方法的執(zhí)行過(guò)程。

執(zhí)行的結(jié)果如下,每一行最后的是代碼行數(shù),我們可以看一下,跟上面代碼是一一對(duì)應(yīng)的。
利用Arthas定位線(xiàn)上問(wèn)題實(shí)例

從代碼中可以看到,如果返回碼是200,那么它會(huì)執(zhí)行第52行,如果返回碼不是200,會(huì)執(zhí)行55行,因此,我們通過(guò)trace功能確定執(zhí)行了哪條語(yǔ)句,就可以知道到底返回沒(méi)返回200,從結(jié)果來(lái)看,確定返回的不是200。

這樣我們就有了確定的證據(jù)證明發(fā)給后臺(tái)時(shí)返回非200,后臺(tái)同事檢查了自己的配置發(fā)現(xiàn)配置有誤,是他們自己的問(wèn)題。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線(xiàn),公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。

網(wǎng)站名稱(chēng):利用Arthas定位線(xiàn)上問(wèn)題實(shí)例-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)URL:http://bm7419.com/article34/diojpe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站虛擬主機(jī)、網(wǎng)站內(nèi)鏈、網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站手機(jī)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁(yè)設(shè)計(jì)公司