熱搜:win11繞過硬件限制安裝 一鍵重裝Win10系統(tǒng) 最干凈的u盤啟動盤 真正純凈版的win7系統(tǒng)
時間:2014-12-03 16:30:16 作者:qipeng 來源:系統(tǒng)之家 1. 掃描二維碼隨時看資訊 2. 請使用手機瀏覽器訪問: https://m.xitongzhijia.net/xtjc/20141203/31828.html 手機查看 評論 反饋
Linux系統(tǒng)的命令有很多,今天小編主要大家介紹下Linux系統(tǒng)監(jiān)控命令,如果你對監(jiān)控命令感興趣或正在學習相關(guān)知識的話,不妨來了解下。
找到最耗CPU的java線程
ps命令
命令:ps -mp pid -o THREAD,tid,time 或者 ps -Lfp pid
結(jié)果展示:
這個命令的作用,主要是可以獲取到對應(yīng)一個進程下的線程的一些信息。 比如你想分析一下一個java進程的一些運行瓶頸點,可以通過該命令找到所有當前Thread的占用CPU的時間,也就是這里的最后一列。
比如這里找到了一個TID : 30834 ,所占用的TIME時間最高。
通過 printf “%x\n” 30834 首先轉(zhuǎn)化成16進制, 繼續(xù)通過jstack命令dump出當前的jvm進程的堆棧信息。 通過Grep命令即可以查到對應(yīng)16進制的線程id信息,很快就可以找到對應(yīng)最耗CPU的代碼快在哪。
簡單的解釋下,jstack下這一串線程信息內(nèi)容:
Java代碼
“DboServiceProcessor-4-thread-295” daemon prio=10 tid=0x00002aab047a9800 nid=0x7d9b waiting on condition [0x0000000046f66000]
nid : 對應(yīng)的linux操作系統(tǒng)下的tid,就是前面轉(zhuǎn)化的16進制數(shù)字
tid: 這個應(yīng)該是jvm的jmm內(nèi)存規(guī)范中的唯一地址定位,如果你詳細分析jvm的一些內(nèi)存數(shù)據(jù)時用得上,我自己還沒到那種程度,所以先放下
top命令
命令:top -Hp pid
結(jié)果顯示:
和前面的效果一下,你可以實時的跟蹤并獲取指定進程中最耗cpu的線程。 再用前面的方法提取到對應(yīng)的線程堆棧信息。
判斷I/O瓶頸
mpstat命令
命令:mpstat -P ALL 1 1000
結(jié)果顯示:
注意一下這里面的%iowait列,CPU等待I/O操作所花費的時間。這個值持續(xù)很高通?赡苁荌/O瓶頸所導致的。
通過這個參數(shù)可以比較直觀的看出當前的I/O操作是否存在瓶頸
發(fā)表評論
共0條
評論就這些咯,讓大家也知道你的獨特見解
立即評論以上留言僅代表用戶個人觀點,不代表系統(tǒng)之家立場