系統(tǒng)之家 - 系統(tǒng)光盤下載網(wǎng)站!

當前位置:系統(tǒng)之家 > 系統(tǒng)教程 > Linux系統(tǒng)監(jiān)控命令

Linux系統(tǒng)監(jiān)控要用到哪些命令?

時間: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)控命令感興趣或正在學習相關知識的話,不妨來了解下。

  找到最耗CPU的java線程

  ps命令

  命令:ps -mp pid -o THREAD,tid,time 或者 ps -Lfp pid

  結果展示:

 Linux系統(tǒng)監(jiān)控要用到哪些命令?

  這個命令的作用,主要是可以獲取到對應一個進程下的線程的一些信息。 比如你想分析一下一個java進程的一些運行瓶頸點,可以通過該命令找到所有當前Thread的占用CPU的時間,也就是這里的最后一列。

  比如這里找到了一個TID : 30834 ,所占用的TIME時間最高。

  通過 printf “%x\n” 30834 首先轉(zhuǎn)化成16進制, 繼續(xù)通過jstack命令dump出當前的jvm進程的堆棧信息。 通過Grep命令即可以查到對應16進制的線程id信息,很快就可以找到對應最耗CPU的代碼快在哪。

 Linux系統(tǒng)監(jiān)控要用到哪些命令?

  簡單的解釋下,jstack下這一串線程信息內(nèi)容:

  Java代碼

  “DboServiceProcessor-4-thread-295” daemon prio=10 tid=0x00002aab047a9800 nid=0x7d9b waiting on condition [0x0000000046f66000]

  nid : 對應的linux操作系統(tǒng)下的tid,就是前面轉(zhuǎn)化的16進制數(shù)字

  tid: 這個應該是jvm的jmm內(nèi)存規(guī)范中的唯一地址定位,如果你詳細分析jvm的一些內(nèi)存數(shù)據(jù)時用得上,我自己還沒到那種程度,所以先放下

  top命令

  命令:top -Hp pid

  結果顯示:

 Linux系統(tǒng)監(jiān)控要用到哪些命令?

  和前面的效果一下,你可以實時的跟蹤并獲取指定進程中最耗cpu的線程。 再用前面的方法提取到對應的線程堆棧信息。

  判斷I/O瓶頸

  mpstat命令

  命令:mpstat -P ALL 1 1000

  結果顯示:

 Linux系統(tǒng)監(jiān)控要用到哪些命令?

  注意一下這里面的%iowait列,CPU等待I/O操作所花費的時間。這個值持續(xù)很高通常可能是I/O瓶頸所導致的。

  通過這個參數(shù)可以比較直觀的看出當前的I/O操作是否存在瓶頸

發(fā)表評論

0

沒有更多評論了

評論就這些咯,讓大家也知道你的獨特見解

立即評論

以上留言僅代表用戶個人觀點,不代表系統(tǒng)之家立場

其他版本軟件

熱門教程

人氣教程排行

Linux系統(tǒng)推薦

官方交流群 軟件收錄