linux系統(tǒng)中有哪些常用的監(jiān)控命令

今天就跟大家聊聊有關(guān)linux系統(tǒng)中有哪些常用的監(jiān)控命令,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

成都創(chuàng)新互聯(lián)致力于互聯(lián)網(wǎng)品牌建設(shè)與網(wǎng)絡(luò)營銷,包括成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)、SEO優(yōu)化、網(wǎng)絡(luò)推廣、整站優(yōu)化營銷策劃推廣、電子商務(wù)、移動互聯(lián)網(wǎng)營銷等。成都創(chuàng)新互聯(lián)為不同類型的客戶提供良好的互聯(lián)網(wǎng)應(yīng)用定制及解決方案,成都創(chuàng)新互聯(lián)核心團(tuán)隊10多年專注互聯(lián)網(wǎng)開發(fā),積累了豐富的網(wǎng)站經(jīng)驗,為廣大企業(yè)客戶提供一站式企業(yè)網(wǎng)站建設(shè)服務(wù),在網(wǎng)站建設(shè)行業(yè)內(nèi)樹立了良好口碑。

找到最耗CPU的java線程ps命令

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

結(jié)果展示:

linux系統(tǒng)中有哪些常用的監(jiān)控命令

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

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

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

linux系統(tǒng)中有哪些常用的監(jiān)控命令

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

"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進(jìn)制數(shù)字

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

top命令

命令:top -Hp pid 

結(jié)果顯示:

linux系統(tǒng)中有哪些常用的監(jiān)控命令

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

判斷I/O瓶頸

mpstat命令

命令:mpstat -P ALL 1 1000

結(jié)果顯示:

linux系統(tǒng)中有哪些常用的監(jiān)控命令

注意一下這里面的%iowait列,CPU等待I/O操作所花費的時間。這個值持續(xù)很高通??赡苁荌/O瓶頸所導(dǎo)致的。

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

iostat命令

命令: iostat -m -x 1 1000


linux系統(tǒng)中有哪些常用的監(jiān)控命令

同樣你可以觀察對應(yīng)的CPU中的%iowait數(shù)據(jù),除此之外iostat還提供了一些更詳細(xì)的I/O狀態(tài)數(shù)據(jù),比如比較重要的有: 

avgqu-sz :  The average queue length of the requests that were issued to the device. (磁盤隊列的請求長度,正常的話2,3比較好??梢院蚦pu的load一樣的理解)

await : The average time (in milliseconds) for I/O requests issued to the device to be served. (代表一個I/O操作從wait到完成的總時間)

svctm和%util都是代表處理該I/O請求花費的時間和CPU的時間比例。 判斷是否瓶頸時,這兩個參數(shù)不是主要的

r/s w/s 和 rMB/s  wMB/s 都是代表當(dāng)前系統(tǒng)處理的I/O的一些狀態(tài),前者是我們常說的tps,后者就是吞吐量。這也是評價一個系統(tǒng)的性能指標(biāo)

pid命令

命令: pidstat -p pid -u -d -t -w -h 1 1000

結(jié)果顯示:
linux系統(tǒng)中有哪些常用的監(jiān)控命令

相當(dāng)實用的一個命令,可以基于當(dāng)個進(jìn)程分析對應(yīng)的性能數(shù)據(jù),包括CPU,I/O,IR , CS等,可以方便開發(fā)者更加精細(xì)化的觀察系統(tǒng)的運行狀態(tài)。不過pidstat貌似是在2.6內(nèi)核的一些較新的版本才有,需要安裝sysstat包。

ubuntu下,可以通過sudo apt-get install sysstat進(jìn)行安裝。

sar命令

命令:sar -x pid 1 1000


linux系統(tǒng)中有哪些常用的監(jiān)控命令

sar也可以指定對應(yīng)的pid,關(guān)注固定的幾個參數(shù),沒有pidstat那么強(qiáng)大。 看不到對應(yīng)的I/O, IR等信息。

sar的功能可以覆蓋mpstat , iostat的相關(guān)功能。

dstat命令

命令:dstat -y --tcp 1 1000


linux系統(tǒng)中有哪些常用的監(jiān)控命令

通過dstat --tcp可以比較方便的看到當(dāng)前的tcp的各種狀態(tài),不需要每次netstat -nat去看

其他命令

netstat -natp  :  查看對應(yīng)的網(wǎng)絡(luò)鏈接,關(guān)注下Recv-Q , Send-Q , State。

lsof -p pid :  查找對應(yīng)pid的文件句柄

lsof -i : 80  : 查找對應(yīng)端口被哪個進(jìn)程占用

lsof  /tmp/1.txt :查找對應(yīng)文件被哪個進(jìn)程占用

tcpdump / wireshark :抓包分析工具

jstat / jmap / jstack / jps 等一系列的java監(jiān)控命令

看完上述內(nèi)容,你們對linux系統(tǒng)中有哪些常用的監(jiān)控命令有進(jìn)一步的了解嗎?如果還想了解更多知識或者相關(guān)內(nèi)容,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。

分享題目:linux系統(tǒng)中有哪些常用的監(jiān)控命令
文章轉(zhuǎn)載:http://muchs.cn/article4/jopeoe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站App設(shè)計、網(wǎng)站營銷、靜態(tài)網(wǎng)站、動態(tài)網(wǎng)站、定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)