【Linux系列-1】top命令詳解

top命令可以說是linux系統資源監控最常用的命令了,top 的輸出格式爲:

top - 20:29:19 up 83 days,  3:42,  2 users,  load average: 7.96, 7.74, 6.15
Tasks: 214 total,   2 running, 212 sleeping,   0 stopped,   0 zombie
%Cpu(s): 50.3 us, 12.4 sy,  0.0 ni, 32.8 id,  0.0 wa,  0.0 hi,  4.5 si,  0.0 st
KiB Mem : 16267784 total,  5136976 free,  9050312 used,  2080496 buff/cache
KiB Swap:  6160380 total,  6005320 free,   155060 used.  5676356 avail Mem 

  PID USER      PR  NI    VIRT    RES    SHR S  %CPU %MEM     TIME+ COMMAND
28509 root      20   0  9.912g 1.812g   7964 S 524.3 11.7   4998:59 java
16168 root      20   0 15.625g 5.199g  18020 S   4.0 33.5 233:32.50 java
   28 root      20   0       0      0      0 S   0.3  0.0   3:02.31 ksoftirqd/4
   33 root      20   0       0      0      0 S   0.3  0.0   2:26.09 ksoftirqd/5
   43 root      20   0       0      0      0 S   0.3  0.0   4:56.15 ksoftirqd/7 
  552 root      20   0       0      0      0 R   0.3  0.0  36:56.82 xfsaild/dm-0
  • top命令默認3s刷新一次
  • cpu數據顯示的是所有cpu使用率的平均值,按1可以查看每個cpu的使用情況

1 結果詳解

以上面的輸出格式爲例,逐行說明。

1.1 第一行

top - 20:29:19 up 83 days,  3:42,  2 users,  load average: 7.96, 7.74, 6.15
  • 21:45:45 — 當前系統時間
  • 1:31 — 系統已經連續運行了1小時31分
  • 2 users — 當前有2個用戶登錄系統
  • load average: 7.96, 7.74, 6.15 — load average後面的三個數分別是1分鐘、5分鐘、15分鐘的負載情況。對於單核cpu,超過1表示滿負載,而對於多核cpu,滿負荷狀態的數字爲 “1.00 * CPU核數”,即雙核CPU對應2.00。

1.2 第二行

Tasks: 214 total,   2 running, 212 sleeping,   0 stopped,   0 zombie
  • Tasks — 任務(進程),系統現在共有214個進程,其中處於運行中的有2個,212個在休眠(sleep),stoped狀態的有0個,zombie狀態(殭屍)的有0個。

1.3 第三行

%Cpu(s): 50.3 us, 12.4 sy,  0.0 ni, 32.8 id,  0.0 wa,  0.0 hi,  4.5 si,  0.0 st

第三行主要描述系統cpu的佔用情況:

  • 50.3 us — 用戶空間佔用CPU的百分比。
  • 12.4 sy — 內核空間佔用CPU的百分比。
  • 0.0 ni — 改變過優先級的進程佔用CPU的百分比
  • 32.8 id — 空閒CPU百分比
  • 0.0% wa — IO等待佔用CPU的百分比
  • 0.0 hi — 硬中斷(Hardware IRQ)佔用CPU的百分比
  • 4.5 si — 軟中斷(Software Interrupts)佔用CPU的百分比
  • 0.0 st —(Steal Time)當 hypervisor 服務另一個虛擬處理器的時候,虛擬 CPU 等待實際 CPU 的時間的百分比

1.4 第四行

KiB Mem : 16267784 total,  5136976 free,  9050312 used,  2080496 buff/cache

第四行描述的是系統的內存使用情況(以kb爲單位):

  • 16267784 total — 物理內存總量
  • 5136976 used — 使用中的內存總量
  • 9050312 free — 空閒內存總量
  • 2080496 buff/cache — 緩存的內存量

1.5 第五行

KiB Swap:  6160380 total,  6005320 free,   155060 used.  5676356 avail Mem 

第五行描述的是交換分區情況:

  • 6160380 total — 交換區總量
  • 155060 used — 使用的交換區總量
  • 6005320 free — 空閒交換區總量
  • 5676356 avail Mem — 可用的交換區總量

2 輸出項目說明

在默認情況下,僅顯示比較重要的 PIO、USERPR、NI、VIRT、RES、SHR、S、%CPU、%MEMTIME+、COMMAND列。
要想展示隱藏項,按 f 鍵進入選擇界面,左側有 * 號的表示該項是展示狀態,通過方向鍵上下移動到某項,按 d 鍵可以改變該項的展示狀態,然後按【ESC】或【q】鍵退出返回top界面。

* PID     = Process Id          
* USER    = Effective User Name 
* PR      = Priority            
* NI      = Nice Value          
* VIRT    = Virtual Image (KiB) 
* RES     = Resident Size (KiB) 
* SHR     = Shared Memory (KiB) 
* S       = Process Status      
* %CPU    = CPU Usage           
* %MEM    = Memory Usage (RES)  
* TIME+   = CPU Time, hundredths
* COMMAND = Command Name/Line   
  PPID    = Parent Process pid  
  UID     = Effective User Id   
  RUID    = Real User Id        
  RUSER   = Real User Name      
  SUID    = Saved User Id       
  SUSER   = Saved User Name     
  GID     = Group Id            
  GROUP   = Group Name          
  PGRP    = Process Group Id    
  TTY     = Controlling Tty     
  TPGID   = Tty Process Grp Id  
  SID     = Session Id          
  nTH     = Number of Threads   
  P       = Last Used Cpu (SMP) 
  TIME    = CPU Time            
  SWAP    = Swapped Size (KiB)  
  CODE    = Code Size (KiB)     
  DATA    = Data+Stack (KiB)    
  nMaj    = Major Page Faults   
  nMin    = Minor Page Faults   
  nDRT    = Dirty Pages Count   
  WCHAN   = Sleeping in Function
  Flags   = Task Flags <sched.h>
  CGROUPS = Control Groups      
  SUPGIDS = Supp Groups IDs     
  SUPGRPS = Supp Groups Names   
  TGID    = Thread Group Id     
  ENVIRON = Environment vars    
  vMj     = Major Faults delta  
  vMn     = Minor Faults delta  
  USED    = Res+Swap Size (KiB) 
  nsIPC   = IPC namespace Inode 
  nsMNT   = MNT namespace Inode 
  nsNET   = NET namespace Inode 
  nsPID   = PID namespace Inode 
  nsUSER  = USER namespace Inode
  nsUTS   = UTS namespace Inode 

各列的含義:

序號 列名 含義
a PID 進程ID
b PPID 父進程ID
c RUSER 真實用戶名
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

3 命令參數

top命令可以後綴不同的參數,從而實現特定目的。

3.1 參數詳解

  1. -b 批次模式運行,通常用來將top的輸出結果傳送給其他程式或儲存成文件。
  2. -d 指定每兩次屏幕信息刷新之間的時間間隔。可以使用s交互命令來改變之。
  3. -p 監控指定進程。監控多個進程時,進程ID之間以逗號分隔,只能在命令行下使用。
  4. -q 該選項將使top沒有任何延遲的進行刷新。如果調用程序有超級用戶權限,那麼top將以儘可能高的優先級運行。
  5. -S 指定累計模式
  6. -s 使top命令在安全模式中運行。這將去除交互命令所帶來的潛在危險。
  7. -i 使top不顯示任何閒置或者僵死進程。
  8. -c 顯示整個命令行而不只是顯示命令名
  9. -n top命令運行n次,一般與-b搭配使用
  10. -H 顯示線程,當這個設定開啓時, 將顯示所有進程產生的線程。
  11. -I 顯示空閒的進程。

3.2 使用示例

  • top -b -d 2 -n 5 -c > result.txt:每2s監控一次,監控5次,並將結果保存到文件中。
  • top -d 2:每隔2秒顯式所有進程的資源佔用情況
  • top –c:每隔5秒顯式進程的資源佔用情況,並顯示進程的命令行參數(默認只有進程名)
  • top -p 12345 -p 6789:每隔5秒顯示pid是12345和pid是6789的兩個進程的資源佔用情況
  • top -d 2 -c -p 123456 :每隔2秒顯示pid是12345的進程的資源使用情況,並顯式該進程啓動的命令行參數
  • top -p -H:顯示一個進程中各個線程CPU的佔用率

4 交互命令

在top界面,可以通過一些指令實時改變顯示內容(區分大小寫):

  • Ctrl+L 擦除並且重寫屏幕。
  • h或者? 顯示幫助畫面,給出一些簡短的命令總結說明。
  • k 終止一個進程。系統將提示用戶輸入需要終止的進程PID,以及需要發送給該進程什麼樣的信號。一般的終止進程可以使用15信號;如果不能正常結束那就使用信號9強制結束該進程。默認值是信號15。在安全模式中此命令被屏蔽。
  • i 忽略閒置和僵死進程。這是一個開關式命令。
  • q 退出程序。
  • r 重新安排一個進程的優先級別。系統提示用戶輸入需要改變的進程PID以及需要設置的進程優先級值。輸入一個正值將使優先級降低,反之則可以使該進程擁有更高的優先權。默認值是10。
  • S 切換到累計模式。
  • s 改變兩次刷新之間的延遲時間。系統將提示用戶輸入新的時間,單位爲s。如果有小數,就換算成m s。輸入0值則系統將不斷刷新,默認值是5 s。
  • f或者F 從當前顯示中添加或者刪除項目。
  • o或者O 改變顯示項目的順序。
  • l 切換顯示平均負載和啓動時間信息。
  • m 切換顯示內存信息。
  • t 切換顯示進程和CPU狀態信息。
  • c 切換顯示命令名稱和完整命令行。
  • M 根據駐留內存大小進行排序。
  • P 根據CPU使用百分比大小進行排序。
  • T 根據時間/累計時間進行排序。
  • W 將當前設置寫入~/.toprc文件中。這是寫top配置文件的推薦方法。
  • <:按當前排序欄位左邊相鄰欄位排序。
  • >:按當前排序欄位右邊相鄰欄位排序。
  • R:反向排序
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章