top命令是Linux下常用的性能分析工具,提供了實時的對系統處理器的狀態監視。它將顯示系統中CPU最“敏感”的任務列表。該命令可以按CPU使用,內存使用和執行時間對任務進行排序;而且該命令的很多特性都可以通過交互式命令或者在個人定製文件中進行設定。類似於Windows的任務管理器。下面詳細介紹它的使用方法。
top - 01:06:48 up 1:22, 1 user, load average: 0.06, 0.60, 0.48
Tasks: 29 total, 1 running, 28 sleeping, 0 stopped, 0 zombie Cpu(s): 0.3% us, 1.0% sy, 0.0% ni, 98.7% id, 0.0% wa, 0.0% hi, 0.0% si Mem: 191272k total, 173656k used, 17616k free, 22052k buffers Swap: 192772k total, 0k used, 192772k free, 123988k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1379 root 16 0 7976 2456 1980 S 0.7 1.3 0:11.03 sshd 14704 root 16 0 2128 980 796 R 0.7 0.5 0:02.72 top 1 root 16 0 1992 632 544 S 0.0 0.3 0:00.90 init 2 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0 3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0 |
統計信息區前五行是系統整體的統計信息。第一行是任務隊列信息,同 uptime 命令的執行結果。其內容如下:
01:06:48
|
當前時間
|
up 1:22
|
系統運行時間,格式爲時:分
|
1 user
|
當前登錄用戶數
|
load average: 0.06, 0.60, 0.48
|
系統負載,即任務隊列的平均長度。
三個數值分別爲 1分鐘、5分鐘、15分鐘前到現在的平均值。 |
第二、三行爲進程和CPU的信息。當有多個CPU時,這些內容可能會超過兩行。顯示用戶模式,系統模式,優先級進程(只有優先級爲負的列入考慮)和閒置等各種情況所佔用CPU時間的百分比。優先級進程所消耗的時間也被列入到用戶和系統的時間中,所以總的百分比將大於100%。內容如下:
Tasks: 29 total
|
進程總數
|
1 running
|
正在運行的進程數
|
28 sleeping
|
睡眠的進程數
|
0 stopped
|
停止的進程數
|
0 zombie
|
殭屍進程數
|
Cpu(s): 0.3% us
|
用戶空間佔用CPU百分比
|
1.0% sy
|
內核空間佔用CPU百分比
|
0.0% ni
|
用戶進程空間內改變過優先級的進程佔用CPU百分比
|
98.7% id
|
空閒CPU百分比
|
0.0% wa
|
等待輸入輸出的CPU時間百分比
|
0.0% hi
|
|
0.0% si
|
最後兩行爲內存信息。內容如下:
Mem: 191272k total
|
物理內存總量
|
173656k used
|
使用的物理內存總量
|
17616k free
|
空閒內存總量
|
22052k buffers
|
用作內核緩存的內存量
|
Swap: 192772k total
|
交換區總量
|
0k used
|
使用的交換區總量
|
192772k free
|
空閒交換區總量
|
123988k cached
|
緩衝的交換區總量。
內存中的內容被換出到交換區,而後又被換入到內存,但使用過的交換區尚未被覆蓋, 該數值即爲這些內容已存在於內存中的交換區的大小。 相應的內存再次被換出時可不必再對交換區寫入。 |
進程信息區統計信息區域的下方顯示了各個進程的詳細信息。首先來認識一下各列的含義。
序號
|
列名
|
含義
|
a
|
PID
|
進程id
|
b
|
PPID
|
父進程id
|
c
|
RUSER
|
Real user name
|
d
|
UID
|
進程所有者的用戶id
|
e
|
USER
|
進程所有者的用戶名
|
f
|
GROUP
|
進程所有者的組名
|
g
|
TTY
|
啓動進程的終端名。不是從終端啓動的進程則顯示爲 ?
|
h
|
PR
|
優先級
|
i
|
NI
|
nice值。負值表示高優先級,正值表示低優先級
|
j
|
P
|
最後使用的CPU,僅在多CPU環境下有意義
|
k
|
%CPU
|
該進程自最近一次刷新以來所佔用的CPU時間和總時間的百分比。
|
l
|
TIME
|
進程使用的CPU時間總計,單位秒
|
m
|
TIME+
|
進程使用的CPU時間總計,單位1/100秒
|
n
|
%MEM
|
進程使用的物理內存百分比
|
o
|
VIRT
|
進程使用的虛擬內存總量,單位kb。VIRT=SWAP+RES
|
p
|
SWAP
|
進程使用的虛擬內存中,被換出的大小,單位kb。
|
q
|
RES
|
進程使用的、未被換出的物理內存大小,單位kb。RES=CODE+DATA
|
r
|
CODE
|
可執行代碼佔用的物理內存大小,單位kb
|
s
|
DATA
|
可執行代碼以外的部分(數據段+棧)佔用的物理內存大小,單位kb
|
t
|
SHR
|
共享內存大小,單位kb
|
u
|
nFLT
|
頁面錯誤次數
|
v
|
nDRT
|
最後一次寫入到現在,被修改過的頁面數。
|
w
|
S
|
進程狀態。
D=不可中斷的睡眠狀態 R=運行 S=睡眠 T=跟蹤/停止 Z=殭屍進程 |
x
|
COMMAND
|
命令名/命令行
|
y
|
WCHAN
|
若該進程在睡眠,則顯示睡眠中的系統函數名
|
z
|
Flags
|
任務標誌,參考 sched.h
|
默認情況下僅顯示比較重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。
下面介紹在top命令執行過程中可以使用的一些交互命令。從使用角度來看,熟練的掌握這些命令比掌握選項還重要一些。這些命令都是單字母的,如果在命令行選項中使用了s選項,則可能其中一些命令會被屏蔽掉。
$#@60;空格立即刷新顯示。
Ctrl+L 擦除並且重寫屏幕。
h或者? 顯示幫助畫面,給出一些簡短的命令總結說明。
k 終止一個進程。系統將提示用戶輸入需要終止的進程PID,以及需要發送給該進程什麼樣的信號。一般的終止進程可以使用15信號;如果不能正常結束那就使用信號9強制結束該進程。默認值是信號15。在安全模式中此命令被屏蔽。
i 忽略閒置和僵死進程。這是一個開關式命令。
q 退出程序。
r 重新安排一個進程的優先級別。系統提示用戶輸入需要改變的進程PID
S 切換到累計模式。
s 改變兩次刷新之間的延遲時間。系統將提示用戶輸入新的時間,單位爲s。如果有小數,就換算成m s。輸入0值則系統將不斷刷新,默認值是5 s。需要注意的是如果設置太小的時間,很可能會引起不斷刷新,從而根本來不及看清顯示的情況,而且系統負載也會大大增加。
f或者F 從當前顯示中添加或者刪除項目。
o或者O 改變顯示項目的順序。
l 切換顯示平均負載和啓動時間信息。
m 切換顯示內存信息。
t 切換顯示進程和CPU狀態信息。
c 切換顯示命令名稱和完整命令行。
M 根據駐留內存大小進行排序。
P 根據CPU使用百分比大小進行排序。
T 根據時間/累計時間進行排序。
W 將當前設置寫入~/.toprc文件中。這是寫top配置文件的推薦方法。
從上面的介紹中可以看到,top命令是一個功能十分強大的監控系統的工具,尤其對於系統管理員而言更是如此。一般的用戶可能會覺得ps命令其實就夠用了,但是top命令的強勁功能確實提供了不少方便。