watch可以幫你監(jiān)測(cè)一個(gè)命令的運(yùn)行結(jié)果,來(lái)監(jiān)測(cè)你想要的一切命令的結(jié)果變化
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、小程序設(shè)計(jì)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了管城免費(fèi)建站歡迎大家使用!
常見(jiàn)命令展示
每隔一秒高亮顯示網(wǎng)絡(luò)鏈接數(shù)的變化情況
說(shuō)明: Ctrl+c 或Ctrl+z 可以退出正在執(zhí)行的watch監(jiān)控進(jìn)程
watch可以同時(shí)運(yùn)行多個(gè)命令,命令間用分號(hào)分隔。
以下命令監(jiān)控磁盤的使用狀況,以及當(dāng)前目錄下文件的變化狀況,包括文件的新增、刪除和文件修改日期的更新等。
top命令動(dòng)態(tài)地監(jiān)視進(jìn)程活動(dòng)與系統(tǒng)負(fù)載等信息。
使用示例:
效果如下圖:
以上命令輸出視圖中分為兩個(gè)區(qū)域,一個(gè)統(tǒng)計(jì)信息區(qū),一個(gè)進(jìn)程信息區(qū)。
統(tǒng)計(jì)信息區(qū):
第一行信息依次為:系統(tǒng)時(shí)間、運(yùn)行時(shí)間、登錄終端數(shù)、系統(tǒng)負(fù)載(三個(gè)數(shù)值分別為1分鐘、5分鐘、15分鐘內(nèi)的平均值,數(shù)值越小意味著負(fù)載越低)。
第二行信息依次為:進(jìn)程總數(shù)、運(yùn)行中的進(jìn)程數(shù)、睡眠中的進(jìn)程數(shù)、停止的進(jìn)程數(shù)、僵死的進(jìn)程數(shù)。
第三行信息依次為:用戶占用資源百分比、系統(tǒng)內(nèi)核占用資源百分比、改變過(guò)優(yōu)先級(jí)的進(jìn)程資源百分比、空閑的資源百分比等。
第四行信息依次為:物理內(nèi)存總量、內(nèi)存使用量、內(nèi)存空閑量、作為內(nèi)核緩存的內(nèi)存量。
第五行信息依次為:虛擬內(nèi)存總量、虛擬內(nèi)存使用量、虛擬內(nèi)存空閑量、預(yù)加載內(nèi)存量。
進(jìn)程信息區(qū):
按 q 鍵退出監(jiān)控頁(yè)面。
uptime 用于查看系統(tǒng)的負(fù)載信息。
使用示例:
查看系統(tǒng)的負(fù)載信息。
效果如下圖:
輸出說(shuō)明:
當(dāng)前服務(wù)器時(shí)間:11:06:57
當(dāng)前服務(wù)器運(yùn)行時(shí)長(zhǎng):59 min
當(dāng)前用戶數(shù):1 users
當(dāng)前負(fù)載情況:load average: 0.00, 0.04, 0.08(分別取1min,5min,15min的均值)
free用于顯示當(dāng)前系統(tǒng)中內(nèi)存的使用量信息。
命令語(yǔ)法: free [-bkmotV][-s 間隔秒數(shù)]
參數(shù)說(shuō)明:
使用示例:
顯示當(dāng)前系統(tǒng)中內(nèi)存的使用量信息。
效果如下圖:
輸出說(shuō)明:
ifconfig命令用于獲取網(wǎng)卡配置與網(wǎng)絡(luò)狀態(tài)等信息。
使用示例:
獲取網(wǎng)卡配置與網(wǎng)絡(luò)狀態(tài)等信息。
效果如下圖:
輸出說(shuō)明:
第一部分的第一行顯示網(wǎng)卡狀態(tài)信息。
eth0表示第一塊網(wǎng)卡。
UP代表網(wǎng)卡開啟狀態(tài)。
RUNNING代表網(wǎng)卡的網(wǎng)線被接上。
MULTICAST表示支持組播。
第二行顯示網(wǎng)卡的網(wǎng)絡(luò)信息。
inet(IP地址):172.16.67.50。
netmask(掩碼地址):255.255.0.0。
broadcast(廣播地址):172.16.255.255。
RX表示接收數(shù)據(jù)包的情況,TX表示發(fā)送數(shù)據(jù)包的情況。
lo表示主機(jī)的回環(huán)網(wǎng)卡,是一種特殊的網(wǎng)絡(luò)接口,不與任何實(shí)際設(shè)備連接,而是完全由軟件實(shí)現(xiàn)。與回環(huán)地址(127.0.0.0/8 或 ::1/128)不同,回環(huán)網(wǎng)卡對(duì)系統(tǒng)顯示為一塊硬件。任何發(fā)送到該網(wǎng)卡上的數(shù)據(jù)都將立刻被同一網(wǎng)卡接收到。
Linux系統(tǒng)top命令的使用方法介紹
在Linux系統(tǒng)中top命令可以用來(lái)監(jiān)測(cè)進(jìn)程的狀態(tài),也可以修改進(jìn)程的優(yōu)先序列。本文就來(lái)教大家Linux系統(tǒng)中top命令的使用方法,一起來(lái)看一下。
1、主要選項(xiàng)
-d:后接秒數(shù),狀態(tài)更新的秒數(shù),默認(rèn)5秒
-b:以批次的方式運(yùn)行top,通常利用重定向?qū)op的輸出重定向到文件
-n:結(jié)合-b使用,運(yùn)行top幾次
-p:指定觀察的進(jìn)程的'PID
2、在 top 執(zhí)行過(guò)程當(dāng)中可以使用的按鍵命令:
?:顯示在 top 當(dāng)中可以輸入按鍵命令
P:按CPU的利用率排序顯示;
M:按內(nèi)存的利用率排序顯示;
N:以 PID排序!
T:由該進(jìn)程使用的CPU時(shí)間累積 (TIME+) 排序。
k:給某個(gè) PID 一個(gè)信號(hào)(signal)
r:給某個(gè) PID 重新指定一個(gè)nice值。
q:退出top。
3、例子
$top -d 2 //每2秒更新一次運(yùn)行狀態(tài)
$top -b -n 2 》 ~/tmp/top.txt //將2次運(yùn)行的狀態(tài)信息導(dǎo)出到文件中
$top -d 2 -p 1425 //每2秒更新一次指定進(jìn)程的運(yùn)行狀態(tài)信息
以上就是Linux中top命令的使用方法的全部?jī)?nèi)容了,所以top命令的功能,有點(diǎn)類似微軟系統(tǒng)中進(jìn)程管理器的功能,使用top命令可以監(jiān)控Linux的性能,具體方法可以參考:《如何使用top命令監(jiān)控Linux系統(tǒng)性能》
記錄一下自己常用的linux系統(tǒng)命令,方便以后查閱,發(fā)覺(jué)記憶越來(lái)越不行了
找到最耗CPU的java線程ps命令
命令:ps -mp pid -o THREAD,tid,time 或者 ps -Lfp pid
結(jié)果展示:
這個(gè)命令的作用,主要是可以獲取到對(duì)應(yīng)一個(gè)進(jìn)程下的線程的一些信息。 比如你想分析一下一個(gè)java進(jìn)程的一些運(yùn)行瓶頸點(diǎn),可以通過(guò)該命令找到所有當(dāng)前Thread的占用CPU的時(shí)間,也就是這里的最后一列。
比如這里找到了一個(gè)TID : 30834 ,所占用的TIME時(shí)間最高。
通過(guò) printf "%x\n" 30834 首先轉(zhuǎn)化成16進(jìn)制, 繼續(xù)通過(guò)jstack命令dump出當(dāng)前的jvm進(jìn)程的堆棧信息。 通過(guò)Grep命令即可以查到對(duì)應(yīng)16進(jìn)制的線程id信息,很快就可以找到對(duì)應(yīng)最耗CPU的代碼快在哪。
簡(jiǎn)單的解釋下,jstack下這一串線程信息內(nèi)容:
"DboServiceProcessor-4-thread-295" daemon prio=10 tid=0x00002aab047a9800 nid=0x7d9b waiting on condition [0x0000000046f66000]
nid : 對(duì)應(yīng)的linux操作系統(tǒng)下的tid,就是前面轉(zhuǎn)化的16進(jìn)制數(shù)字
tid: 這個(gè)應(yīng)該是jvm的jmm內(nèi)存規(guī)范中的唯一地址定位,如果你詳細(xì)分析jvm的一些內(nèi)存數(shù)據(jù)時(shí)用得上,我自己還沒(méi)到那種程度,所以先放下
top命令
命令:top -Hp pid
結(jié)果顯示:
和前面的效果一下,你可以實(shí)時(shí)的跟蹤并獲取指定進(jìn)程中最耗cpu的線程。 再用前面的方法提取到對(duì)應(yīng)的線程堆棧信息。
判斷I/O瓶頸
mpstat命令
命令:mpstat -P ALL 1 1000
結(jié)果顯示:
注意一下這里面的%iowait列,CPU等待I/O操作所花費(fèi)的時(shí)間。這個(gè)值持續(xù)很高通??赡苁荌/O瓶頸所導(dǎo)致的。
通過(guò)這個(gè)參數(shù)可以比較直觀的看出當(dāng)前的I/O操作是否存在瓶頸
iostat命令
命令: iostat -m -x 1 1000
同樣你可以觀察對(duì)應(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. (磁盤隊(duì)列的請(qǐng)求長(zhǎng)度,正常的話2,3比較好??梢院蚦pu的load一樣的理解)
await : The average time (in milliseconds) for I/O requests issued to the device to be served. (代表一個(gè)I/O操作從wait到完成的總時(shí)間)
svctm和%util都是代表處理該I/O請(qǐng)求花費(fèi)的時(shí)間和CPU的時(shí)間比例。 判斷是否瓶頸時(shí),這兩個(gè)參數(shù)不是主要的
r/s w/s 和 rMB/s wMB/s 都是代表當(dāng)前系統(tǒng)處理的I/O的一些狀態(tài),前者是我們常說(shuō)的tps,后者就是吞吐量。這也是評(píng)價(jià)一個(gè)系統(tǒng)的性能指標(biāo)
pid命令
命令: pidstat -p pid -u -d -t -w -h 1 1000
結(jié)果顯示:
相當(dāng)實(shí)用的一個(gè)命令,可以基于當(dāng)個(gè)進(jìn)程分析對(duì)應(yīng)的性能數(shù)據(jù),包括CPU,I/O,IR , CS等,可以方便開發(fā)者更加精細(xì)化的觀察系統(tǒng)的運(yùn)行狀態(tài)。不過(guò)pidstat貌似是在2.6內(nèi)核的一些較新的版本才有,需要安裝sysstat包。
ubuntu下,可以通過(guò)sudo apt-get install sysstat進(jìn)行安裝。
sar命令
命令:sar -x pid 1 1000
sar也可以指定對(duì)應(yīng)的pid,關(guān)注固定的幾個(gè)參數(shù),沒(méi)有pidstat那么強(qiáng)大。 看不到對(duì)應(yīng)的I/O, IR等信息。
sar的功能可以覆蓋mpstat , iostat的相關(guān)功能。
dstat命令
命令:dstat -y --tcp 1 1000
通過(guò)dstat --tcp可以比較方便的看到當(dāng)前的tcp的各種狀態(tài),不需要每次netstat -nat去看
其他命令
netstat -natp : 查看對(duì)應(yīng)的網(wǎng)絡(luò)鏈接,關(guān)注下Recv-Q , Send-Q , State。
lsof -p pid : 查找對(duì)應(yīng)pid的文件句柄
lsof -i : 80 : 查找對(duì)應(yīng)端口被哪個(gè)進(jìn)程占用
lsof /tmp/1.txt :查找對(duì)應(yīng)文件被哪個(gè)進(jìn)程占用
tcpdump / wireshark :抓包分析工具
jstat / jmap / jstack / jps 等一系列的java監(jiān)控命令
最后
如果你想做一些性能調(diào)優(yōu)的工作,一定要善于利用一些工具進(jìn)行關(guān)注相應(yīng)的狀態(tài)。通過(guò)linux命令你可以比較方便的觀測(cè)到CPU , I/O , network等一些比較外圍的狀態(tài), 很多時(shí)候就已經(jīng)可以解決大部分的問(wèn)題。jvm內(nèi)部的一些運(yùn)行狀態(tài)監(jiān)控,得需要借助一些特有的工具進(jìn)行細(xì)粒度的觀測(cè)。