Linux系統(tǒng)top命令的使用方法介紹
網(wǎng)站建設哪家好,找創(chuàng)新互聯(lián)建站!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、微信小程序定制開發(fā)、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了淮北免費建站歡迎大家使用!
在Linux系統(tǒng)中top命令可以用來監(jiān)測進程的狀態(tài),也可以修改進程的優(yōu)先序列。本文就來教大家Linux系統(tǒng)中top命令的使用方法,一起來看一下。
1、主要選項
-d:后接秒數(shù),狀態(tài)更新的秒數(shù),默認5秒
-b:以批次的方式運行top,通常利用重定向?qū)op的輸出重定向到文件
-n:結合-b使用,運行top幾次
-p:指定觀察的進程的'PID
2、在 top 執(zhí)行過程當中可以使用的按鍵命令:
?:顯示在 top 當中可以輸入按鍵命令
P:按CPU的利用率排序顯示;
M:按內(nèi)存的利用率排序顯示;
N:以 PID排序!
T:由該進程使用的CPU時間累積 (TIME+) 排序。
k:給某個 PID 一個信號(signal)
r:給某個 PID 重新指定一個nice值。
q:退出top。
3、例子
$top -d 2 //每2秒更新一次運行狀態(tài)
$top -b -n 2 》 ~/tmp/top.txt //將2次運行的狀態(tài)信息導出到文件中
$top -d 2 -p 1425 //每2秒更新一次指定進程的運行狀態(tài)信息
以上就是Linux中top命令的使用方法的全部內(nèi)容了,所以top命令的功能,有點類似微軟系統(tǒng)中進程管理器的功能,使用top命令可以監(jiān)控Linux的性能,具體方法可以參考:《如何使用top命令監(jiān)控Linux系統(tǒng)性能》
top命令分為匯總區(qū)和任務明細區(qū)
當前時間是15:39:37. 系統(tǒng)已經(jīng)運行了90天,15個小時,26分鐘。當前有兩個活躍用戶
上下兩行以kb形式展示物理內(nèi)存和swap內(nèi)存的總計,空閑(free), 已使用(total)的情況
其中buff/cache ,是在cpu讀寫硬盤數(shù)據(jù)時,為了提速在內(nèi)存中開辟的緩沖(buffer針對寫)或緩存區(qū)域(cache針對讀)
avail mem 是創(chuàng)建新進程時,在不使用swap分區(qū)的情況下,能夠分配的內(nèi)存大小。這個大小可能比當前的free還大,這是因為buff/cache中的內(nèi)存在創(chuàng)建進程時,若需要,也是可以搶占過來的。
總共有27個進程,1個運行,26的sleep中
load average后面的三組數(shù)字分別是1分鐘、5分鐘、15分鐘的工作負載情況。這里的Load指的出于R(runing)和D(Uninterruptible sleep)的兩種狀態(tài)下的進程數(shù)
在單核cpu情況下。load average 為0.4的表示,其cpu利用率只有40%。 load average 為1,表示cpu利用率為100。load average 為2.12說明,cpu已經(jīng)超負荷112% (2.12減滿負荷1,即為超負荷部分)
在多核cpu的機器上,需要將以上的1,5,15的負載除以對應的cpu核數(shù),才好評估對應的cpu的負載情況
比如,這個cpu為40核的機器上,其cpu過去一分鐘的使用情況為:8.26/40=0.2065 ,說明cpu使用率只有20%
展示每個進程的情況
在top名稱執(zhí)行后,按小k,可以進入進程殺死對話框
在后面輸入進程號,即可殺死進程
在top命令下
按以下大寫字母,分別按不同的維度進行排序
當然你也可以在命令啟動時,直接對top加參數(shù)。比如以cpu使用情況排序
top命令默認顯示的進程的運行情況,在top命令執(zhí)行后,按大寫的H,可進入線程執(zhí)行情況頁面,再按一次H則會到進程展示?;蛘咴趩訒r對top加參數(shù) top -H
在top執(zhí)行后,按小c,則能夠展示進程路徑,并且對內(nèi)核進程的名稱(command列),加上方括號。再按c切換回去
當然也可以在啟動時,加參數(shù) top -c
top執(zhí)行后按大V
在top啟動后,按小寫u,在輸入框中輸入對應的用戶名
或者在top啟動時,通過加參數(shù)來過濾用戶 top -u root
在top啟動后,按大O,進入過濾表達式的輸入框
表達式有以下幾種類型
輸入等號'=',清除filter表達式
在top命令下,按t或m來進行進度條顯示
首先基于 ps aux | grep processName 找到對應進程的pid
然后使用 top -c -p pid 方式單過濾查看該進程的資源占用情況
top命令用于顯示系統(tǒng)運行的進程信息,作用類似于windows中的任務管理器,只不過top不是圖形化的,而是顯示實時文本信息\x0d\x0a\x0d\x0a統(tǒng)計信息區(qū)域的下方顯示了各個進程的詳細信息。首先來認識一下各列的含義。\x0d\x0aPID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND\x0d\x0a序號列名含義\x0d\x0aPID 進程id\x0d\x0aPPID 父進程id\x0d\x0aRUSER Realusername\x0d\x0aUID 進程所有者的用戶id\x0d\x0aUSER 進程所有者的用戶名\x0d\x0aGROUP 進程所有者的組名\x0d\x0aTTY 啟動進程的終端名。不是從終端啟動的進程則顯示為?\x0d\x0aPR 優(yōu)先級\x0d\x0aNInice 值。負值表示高優(yōu)先級,正值表示低優(yōu)先級\x0d\x0aP 最后使用的CPU,僅在多CPU環(huán)境下有意義\x0d\x0a%CPU 上次更新到現(xiàn)在的CPU時間占用百分比\x0d\x0aTIME 進程使用的CPU時間總計,單位秒\x0d\x0aTIME+ 進程使用的CPU時間總計,單位1/100秒\x0d\x0a%MEM 進程使用的物理內(nèi)存百分比\x0d\x0aVIRT 進程使用的虛擬內(nèi)存總量,單位kb。VIRT=SWAP+RES\x0d\x0aSWAP 進程使用的虛擬內(nèi)存中,被換出的大小,單位kb。\x0d\x0aRES 進程使用的、未被換出的物理內(nèi)存大小,單位kb。RES=CODE+DATA\x0d\x0aCODE 可執(zhí)行代碼占用的物理內(nèi)存大小,單位kb\x0d\x0aDATA 可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小,單位kb\x0d\x0aSHR 共享內(nèi)存大小,單位kb\x0d\x0anFLT 頁面錯誤次數(shù)\x0d\x0anDRT 最后一次寫入到現(xiàn)在,被修改過的頁面數(shù)。\x0d\x0aS 進程狀態(tài)。\x0d\x0aD= 不可中斷的睡眠狀態(tài)\x0d\x0aR= 運行\(zhòng)x0d\x0aS= 睡眠\x0d\x0aT= 跟蹤/停止\x0d\x0aZ= 僵尸進程\x0d\x0aCOMMAND 命令名/命令行\(zhòng)x0d\x0aWCHAN 若該進程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名\x0d\x0aFlags 任務標志,參考sched.h