最近發(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/