歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
您现在的位置: Linux教程網 >> UnixLinux >  >> Linux基礎 >> Linux教程

常用的Linux系統監控命令介紹

記錄一下自己常用的Linux系統命令,方便以後查閱,發覺記憶越來越不行了

找到最耗CPU的java線程

ps命令

命令:

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

結果展示:

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

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

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

  簡單的解釋下,jstack下這一串線程信息內容:

800 nid=0x7d9b waiting on condition <0x0000000046f66000>

"DboServiceProcessor-4-thread-295" daemon prio=10 tid=0x00002aab047a9800 nid=0x7d9b waiting on condition <0x0000000046f66000>

  nid : 對應的linux操作系統下的tid,就是前面轉化的16進制數字

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

top命令

命令:

top -Hp pid

結果顯示:

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

判斷I/O瓶頸

mpstat命令

命令:mpstat -P ALL 1 1000

結果顯示:

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

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

Copyright © Linux教程網 All Rights Reserved