使用arthas進(jìn)行線上java應(yīng)用診斷

最近發(fā)現(xiàn)一個(gè)挺好用的工具:alibaba出的Arthas复凳。這是一個(gè)java應(yīng)用線上診斷工具甸昏。如果你之前用過(guò)Btrace蛤迎,那么理解起來(lái)Arthas就不難蜓陌。這兩個(gè)都是java線上應(yīng)用診斷工具觅彰。比如你想了解當(dāng)前執(zhí)行應(yīng)用的內(nèi)存占用,線程情況钮热,具體參數(shù)值等信息缔莲,無(wú)需麻煩的打日志,上線就可以用上面的工具輕輕松松解決問(wèn)題霉旗。

之前也了解過(guò)Btrace,但是鑒于用起來(lái)太麻煩蛀骇,一直不喜歡用厌秒。這次發(fā)現(xiàn)了Arthas,用起來(lái)簡(jiǎn)直不要太方便擅憔。這兩個(gè)工具的功能類(lèi)似鸵闪,要說(shuō)區(qū)別嘛舉個(gè)例子對(duì)比就是:你把Btrace比作飛刀,如果你是李尋歡暑诸,那么憑借這把飛到什么妖魔鬼怪你都可以干掉蚌讼。而Arthas理解為AK-47。拿著這玩意个榕,我們普通人也可以橫掃天下了??篡石。

為了讓不了解Arthas的小伙伴不要太懵逼,下面先摘錄Arthas官方的一段話來(lái)說(shuō)明它能干嘛

當(dāng)你遇到以下類(lèi)似問(wèn)題而束手無(wú)策時(shí)西采,Arthas可以幫助你解決:

- 這個(gè)類(lèi)從哪個(gè) jar 包加載的凰萨?為什么會(huì)報(bào)各種類(lèi)相關(guān)的 Exception?
- 我改的代碼為什么沒(méi)有執(zhí)行到械馆?難道是我沒(méi) commit胖眷?分支搞錯(cuò)了?
- 遇到問(wèn)題無(wú)法在線上 debug霹崎,難道只能通過(guò)加日志再重新發(fā)布嗎珊搀?
- 線上遇到某個(gè)用戶(hù)的數(shù)據(jù)處理有問(wèn)題,但線上同樣無(wú)法 debug尾菇,線下無(wú)法重現(xiàn)境析!
- 是否有一個(gè)全局視角來(lái)查看系統(tǒng)的運(yùn)行狀況囚枪?
- 有什么辦法可以監(jiān)控到JVM的實(shí)時(shí)運(yùn)行狀態(tài)?

Arthas支持JDK 6+簿晓,支持Linux/Mac/Winodws眶拉,采用命令行交互模式,同時(shí)提供豐富的 Tab 自動(dòng)補(bǔ)全功能憔儿,進(jìn)一步方便進(jìn)行問(wèn)題的定位和診斷忆植。

怎么樣?是不是小伙伴們的福音谒臼?下次系統(tǒng)再有問(wèn)題朝刊,就可以不用麻煩運(yùn)維哥哥一遍又一遍的發(fā)布打了一堆日志的應(yīng)用了。

Arthas官方文檔非常好用蜈缤,小伙伴們可以點(diǎn)擊這里查看使用:https://alibaba.github.io/arthas/

我這里僅記錄下我最近使用它處理線上問(wèn)題的經(jīng)歷拾氓,讓你看看是不是很好用

最近產(chǎn)品妹妹提了個(gè)需求,要生成最近30天的每天的業(yè)務(wù)報(bào)表底哥。在下一頓操作猛如虎咙鞍,功能上線了,由于之前已經(jīng)有個(gè)定時(shí)任務(wù)會(huì)自動(dòng)生成每天的報(bào)表趾徽,所以续滋,我在定時(shí)任務(wù)上加了個(gè)參數(shù),可以指定具體日期孵奶,這樣就勝場(chǎng)那天的報(bào)表疲酌。
在線上是我配置個(gè)參數(shù):{"reportDate":"2019-08-05"},執(zhí)行后發(fā)現(xiàn)生成的不是8月5日的報(bào)表了袁,而是生成了當(dāng)天的朗恳,我程序里有判斷如果沒(méi)有傳指定日期就生成當(dāng)天的報(bào)表。但是我明明傳了呀载绿。
我排查問(wèn)題的思路如下:

  • 1,確保我新調(diào)整的代碼上線了
  • 2,確保我在頁(yè)面設(shè)置的參數(shù)有傳到指定的方法
  • 3,那個(gè)方法我本地有做單元測(cè)試執(zhí)行是沒(méi)問(wèn)題的粥诫,所以上面兩步驟應(yīng)該就可以查出問(wèn)題了

那么針對(duì)第一個(gè)問(wèn)題,以往我得解決辦法是崭庸,直接把指定代碼所在的jar包下載到本地臀脏,用反編譯工具反編譯代碼后查看代碼是否是我想要的,但是現(xiàn)在不用這么麻煩啦冀自,
我直接用jad命令 就可以查看線上的源代碼揉稚。
首先下載arthas工具,并啟動(dòng)

wget https://alibaba.github.io/arthas/arthas-boot.jar
java -jar arthas-boot.jar

啟動(dòng)后根據(jù)程序進(jìn)程id選擇要診斷的程序,然后使用jad命令加上類(lèi)名(包括包名)就可以查看具體類(lèi)的源碼了熬粗。

jad  com.xxx.schedule.job.ReportJob

查看后發(fā)現(xiàn)代碼是最新的搀玖,沒(méi)問(wèn)題

接下來(lái)進(jìn)入第二步,既然代碼沒(méi)問(wèn)題驻呐,那么難道是參數(shù)沒(méi)有傳進(jìn)來(lái)灌诅?怎么辦芳来,以前的思路,只能在在代碼里打印出來(lái)參數(shù)重新發(fā)布了猜拾。

但是現(xiàn)在不需要啦即舌,一個(gè)watch命令就搞定,wtch可以監(jiān)聽(tīng)指定方法里的參數(shù)挎袜,當(dāng)這個(gè)方法執(zhí)行的時(shí)候輸出參數(shù)的信息
具體用法為:

watch com.xxx.schedule.job.ReportJob(類(lèi)名) execute(方法名) params(表示監(jiān)聽(tīng)該方法的參數(shù))

然后我讓定時(shí)任務(wù)重新執(zhí)行了一遍顽聂。高潮來(lái)了,天盯仪,竟然參數(shù)也傳過(guò)來(lái)了紊搪。參數(shù)也傳過(guò)來(lái),但是我程序依然沒(méi)有用該參數(shù)全景,那是什么問(wèn)題呢耀石。難道是因?yàn)閰?shù)有問(wèn)題?

趕緊爬到屏幕上仔細(xì)看了下參數(shù)爸黄,果然滞伟,一個(gè)驚天小問(wèn)題:
參數(shù)是json格式的,json里面雙引號(hào)應(yīng)該是半角的炕贵,我把其中一個(gè)雙引號(hào)寫(xiě)成全角的了梆奈,不仔細(xì)看還真看不出來(lái)。

{"reportDate","2019-08-05"}
{“reportDate","2019-08-05"}

怎么樣鲁驶,忽略我的粗心大意之后,剩下的——Arthas是不是很好用N杪妗T客洹!

歡迎來(lái)鄙人的小窩交流
http://blog.enilu.cn/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末督禽,一起剝皮案震驚了整個(gè)濱河市脆霎,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌狈惫,老刑警劉巖睛蛛,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異胧谈,居然都是意外死亡忆肾,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)菱肖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)客冈,“玉大人,你說(shuō)我怎么就攤上這事稳强〕≈伲” “怎么了和悦?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)渠缕。 經(jīng)常有香客問(wèn)我鸽素,道長(zhǎng),這世上最難降的妖魔是什么亦鳞? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任馍忽,我火速辦了婚禮,結(jié)果婚禮上蚜迅,老公的妹妹穿的比我還像新娘舵匾。我一直安慰自己,他們只是感情好谁不,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布坐梯。 她就那樣靜靜地躺著,像睡著了一般刹帕。 火紅的嫁衣襯著肌膚如雪吵血。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天偷溺,我揣著相機(jī)與錄音蹋辅,去河邊找鬼。 笑死挫掏,一個(gè)胖子當(dāng)著我的面吹牛侦另,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播尉共,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼褒傅,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了袄友?” 一聲冷哼從身側(cè)響起殿托,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎剧蚣,沒(méi)想到半個(gè)月后支竹,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡鸠按,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年礼搁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片目尖。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡叹坦,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出卑雁,到底是詐尸還是另有隱情募书,我是刑警寧澤绪囱,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站莹捡,受9級(jí)特大地震影響鬼吵,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜篮赢,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一齿椅、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧启泣,春花似錦涣脚、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至纱耻,卻和暖如春芭梯,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背弄喘。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工玖喘, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蘑志。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓累奈,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親急但。 傳聞我的和親對(duì)象是個(gè)殘疾皇子澎媒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355