天天看點

[網絡摘錄學習]常用的Linux系統監控指令

找到最耗cpu的java線程

ps指令

指令:

結果展示:

[網絡摘錄學習]常用的Linux系統監控指令

這個指令的作用,主要是可以擷取到對應一個程序下的線程的一些資訊。 比如你想分析一下一個java程序的一些運作瓶頸點,可以通過該指令找到所有目前thread的占用cpu的時間,也就是這裡的最後一列。

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

通過 printf "%x\n" 30834 首先轉化成16進制, 繼續通過jstack指令dump出目前的jvm程序的堆棧資訊。 通過grep指令即可以查到對應16進制的線程id資訊,很快就可以找到對應最耗cpu的代碼快在哪。

[網絡摘錄學習]常用的Linux系統監控指令

簡單的解釋下,jstack下這一串線程資訊内容:

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

tid: 這個應該是jvm的jmm記憶體規範中的唯一位址定位,如果你詳細分析jvm的一些記憶體資料時用得上,我自己還沒到那種程度,是以先放下

top指令

結果顯示:

[網絡摘錄學習]常用的Linux系統監控指令

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

判斷i/o瓶頸

mpstat指令

指令:mpstat -p all 1 1000

[網絡摘錄學習]常用的Linux系統監控指令

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

通過這個參數可以比較直覺的看出目前的i/o操作是否存在瓶頸

iostat指令

指令:

[網絡摘錄學習]常用的Linux系統監控指令

同樣你可以觀察對應的cpu中的%iowait資料,除此之外iostat還提供了一些更詳細的i/o狀态資料,比如比較重要的有:

svctm和%util都是代表處理該i/o請求花費的時間和cpu的時間比例。 判斷是否瓶頸時,這兩個參數不是主要的

r/s w/s 和 rmb/s wmb/s 都是代表目前系統處理的i/o的一些狀态,前者是我們常說的tps,後者就是吞吐量。這也是評價一個系統的性能名額

pid指令

[網絡摘錄學習]常用的Linux系統監控指令

相當實用的一個指令,可以基于當個程序分析對應的性能資料,包括cpu,i/o,ir , cs等,可以友善開發者更加精細化的觀察系統的運作狀态。不過pidstat貌似是在2.6核心的一些較新的版本才有,需要安裝sysstat包。

ubuntu下,可以通過sudo apt-get install sysstat進行安裝。

sar指令

[網絡摘錄學習]常用的Linux系統監控指令

sar也可以指定對應的pid,關注固定的幾個參數,沒有pidstat那麼強大。 看不到對應的i/o, ir等資訊。

sar的功能可以覆寫mpstat , iostat的相關功能。

dstat指令

[網絡摘錄學習]常用的Linux系統監控指令

通過dstat --tcp可以比較友善的看到目前的tcp的各種狀态,不需要每次netstat -nat去看

其他指令

netstat -natp : 檢視對應的網絡連結,關注下recv-q , send-q , state。

lsof -p pid : 查找對應pid的檔案句柄

lsof -i : 80 : 查找對應端口被哪個程序占用

lsof /tmp/1.txt :查找對應檔案被哪個程序占用

tcpdump / wireshark :抓包分析工具

jstat / jmap / jstack / jps 等一系列的java監控指令

最後

如果你想做一些性能調優的工作,一定要善于利用一些工具進行關注相應的狀态。通過linux指令你可以比較友善的觀測到cpu , i/o , network等一些比較外圍的狀态, 很多時候就已經可以解決大部分的問題。jvm内部的一些運作狀态監控,得需要借助一些特有的工具進行細粒度的觀測。

原文:http://agapple.iteye.com/blog/1156719

轉載請注明出處:http://www.cnblogs.com/haochuang/ 8年it工作經驗,5年測試技術與管理,2年産品與項目管理,曾參與過雲計算\雲存儲\車聯網産品研發工作; 業餘自媒體人,有技術類垂直微信公衆号;如有招聘或求職方面需求,請mail to [email protected] ;或通過 qq:363573922 微網誌:@念槐聚 聯系;