top命令和ps命令的基本做用是相同的,顯示系統當前的進程和其餘情況;可是top是一個動態顯示過程,便可以經過用戶按鍵來不斷刷新當前狀態。若是在前臺執行該命令,它將獨佔前臺,直到用戶終止該程序爲止。 比較準確的說,top命令提供了實時的對系統處理器的狀態監視。它將顯示系統中CPU最「敏感」的任務列表。該命令能夠按CPU使用。內存使用和執行時間對任務進行排序;並且該命令的不少特性均可以經過交互式命令或者在我的定製文件中進行設定。在後面的介紹中將把命令參數和交互命令分開講述。
下面是該命令的語法格式:
top [-] [d delay] [q] [c] [s] [S]
d 指定每兩次屏幕信息刷新之間的時間間隔。固然用戶可使用s交互命令來改變之。
q 該選項將使top沒有任何延遲的進行刷新。若是調用程序有超級用戶權限,那麼top將以儘量高的
優先級運行。
S 指定累計模式。
s 使top命令在
安全模式中運行。這將去除交互命令所帶來的潛在危險。
c 顯示整個命令行而不僅是顯示命令名
top命令顯示的項目不少,默認值是每5秒更新一次,固然這是能夠設置的。
顯示的各項目爲: uptime 該項顯示的是系統啓動時間、已經運行的時間和三個平均負載值(最近1秒,5秒,15秒的負載值)。 processes 自最近一次刷新以來的運行進程總數。固然這些進程被分爲正在運行的,休眠的,中止的等不少種類。進程和狀態顯示能夠經過交互命令t來實現。
CPU states 顯示用戶模式,系統模式,
優先級進程(只有優先級爲負的列入考慮)和閒置等各類狀況所佔用
CPU時間的百分比。優先級進程所消耗的時間也被列入到用戶和系統的時間中,因此總的百分比將大於100%。
Mem 內存使用狀況統計,其中包括總的可用內存,空閒內存,已用內存,
共享內存和緩存所佔內存的狀況。
Swap 交換空間統計,其中包括總的交換空間,可用交換空間,已用交換空間。
PID 每一個進程的ID。
UID 每一個進程全部者的UID 。
USER 每一個進程全部者的用戶名。
PRI 每一個進程的優先級別。
SIZE 該進程的代碼大小加上數據大小再加上
堆棧空間大小的總數。單位是KB。
TSIZE 該進程的代碼大小。對於
內核進程這是一個很奇怪的值。
DSIZE 數據和堆棧的大小。
TRS 文本駐留大小。
D 被標記爲「不乾淨」的頁項目。
LIB 使用的庫頁的大小。對於ELF進程沒有做用。
RSS 該進程佔用的
物理內存的總數量,單位是KB。
STAT 該進程的狀態。
D表明不可中斷的休眠狀態;
R表明運行狀態;
Z表明僵死狀態;
T表明中止或跟蹤狀態。
TIME 該進程自啓動以來所佔用的總
CPU時間。若是進入的是累計模式,那麼該時間還包括這個進程子進程所佔用的時間。且標題會變成
CTIME。
%CPU 該進程自最近一次刷新以來所佔用的CPU時間和總時間的百分比。
%MEM 該進程佔用的
物理內存佔總內存的百分比。
COMMAND 該進程的命令名稱,若是一行顯示不下,則會進行截取。內存中的進程會有一個完整的命令行。
下面介紹在top命令執行過程當中可使用的一些交互命令。從使用角度來看,熟練的掌握這些命令比掌握選項還重要一些。這些命令都是單字母的,若是在命令行選項中使用了s選項,則可能其中一些命令會被屏蔽掉。
<空格> 當即刷新顯示。
Ctrl+L 擦除而且重寫屏幕。
h或者? 顯示幫助畫面,給出一些簡短的命令總結說明。
k 終止一個進程。系統將提示用戶輸入須要終止的進程PID,以及須要發送給該進程什麼樣的信號。通常的終止進程可使用15信號;若是不能正常結束那就使用信號9強制結束該進程。默認值是信號15。在
安全模式中此命令被屏蔽。
q 退出程序。
r 從新安排一個進程的優先級別。系統提示用戶輸入須要改變的進程PID以及須要設置的
進程優先級值。輸入一個正值將使
優先級下降,反之則可使該進程擁有更高的優先權。默認值是10。
S 切換到累計模式。
s 改變兩次刷新之間的延遲時間。系統將提示用戶輸入新的時間,單位爲s。若是有小數,就換算成m s。輸入0值則系統將不斷刷新,默認值是5 s。須要注意的是若是設置過小的時間,極可能會引發不斷刷新,從而根原本不及看清顯示的狀況,並且系統負載也會大大增長。
f或者F 從當前顯示中添加或者刪除項目。
o或者O 改變顯示項目的順序。
l 切換顯示平均負載和啓動時間信息。
t 切換顯示進程和CPU狀態信息。
c 切換顯示命令名稱和完整命令行。
M 根據駐留內存大小進行排序。
P 根據CPU使用百分比大小進行排序。
T 根據時間/累計時間進行排序。
W 將當前設置寫入~/.toprc文件中。這是寫top配置文件的推薦方法。
從上面的介紹中能夠看到,top命令是一個功能十分強大的監控系統的工具,尤爲對於
系統管理員而言更是如此。通常的用戶可能會以爲ps命令其實就夠用了,可是top命令的強勁功能確實提供了很多方便。下面來看看實際使用的狀況。
[例23] 鍵入top命令查看系統情況
$ top
1:55pm up 7 min, 4 user, load average:0.07,0.09,0.06
29 processes:28 sleeping, 1 running, 0 zombie, 0 stopped
CPU states: 4.5% user, 3.6% system, 0.0% nice, 91.9% idle
Mem: 38916K av, 18564K used, 20352K free, 11660K shrd, 1220K buff
Swap: 33228K av, 0K used, 33228K free, 11820K cached
PID USER PRI NI SIZE RSS SHARE STAT LIB %CPU %MEM TIME COMMAND
363 root 14 0 708 708 552 R 0 8.1 1.8 0:00 top
1 root 0 0 404 404 344 S 0 0.0 1.0 0:03 init
2 root 0 0 0 0 0 SW 0 0.0 0.0 0:00 kflushd
3 root -12 -12 0 0 0 SW< 0 0.0 0.0 0:00 kswapd
4 root 0 0 0 0 0 SW 0 0.0 0.0 0:00 md_thread
5 root 0 0 0 0 0 SW 0 0.0 0.0 0:00 md_thread
312 root 1 0 636 636 488 S 0 0.0 1.6 0:00 telnet
285 root 6 0 1140 1140 804 S 0 0.0 2.9 0.00 bash
286 root 0 0 1048 1048 792 S 0 0.0 2.6 0.00 bash
25 root 0 0 364 364 312 S 0 0.0 0.9 0.00 kerneld
153 root 0 0 456 456 372 S 0 0.0 1.1 0.00 syslogd
160 root 0 0 552 552 344 S 0 0.0 1.4 0.00 klogd
169 daemon 0 0 416 416 340 S 0 0.0 1.0 0.00 atd
178 root 2 0 496 496 412 S 0 0.0 1.2 0.00 crond
187 bin 0 0 352 352 284 S 0 0.0 0.9 0.00 portmap
232 root 0 0 500 500 412 S 0 0.0 1.2 0.00 rpc.mountd
206 root 0 0 412 412 344 S 0 0.0 1.0 0.00 inetd
215 root 0 0 436 436 360 S 0 0.0 1.1 0.00 icmplog
第一行的項目依次爲當前時間、系統啓動時間、當前系統登陸用戶數目、平均負載。第二行爲進程狀況,依次爲進程總數、休眠進程數、運行進程數、
僵死進程數、終止進程數。第三行爲CPU狀態,依次爲用戶佔用、系統佔用、優先進程佔用、閒置進程佔用。第四行爲內存狀態,依次爲平都可用內存、已用內存、空閒內存、
共享內存、
緩存使用內存。第五行爲交換狀態,依次爲平都可用交換容量、已用容量、閒置容量、高速緩存容量。而後下面就是和ps相仿的各進程狀況列表了。