1. 程式人生 > 其它 >Linux中CPU、磁碟、網路監測命令

Linux中CPU、磁碟、網路監測命令

1.top命令
是常用來監控linux的系統狀態,是常用的效能分析工具,能夠實時顯示系統中各個程序的資源佔用情況。

可以使用 top 指令查出 JVM 中佔用 CPU 過高的執行緒,通過 jstack 找到對應的執行緒程式碼呼叫,排查出問題程式碼。
jstack是 java stack(java堆疊)的縮寫

top使用方式:
top [-d number] | top [-bnp]
引數解釋:
-d: number代表秒數,表示top命令顯示的頁面更新一次的間隔。預設是5秒。-b:以批次的方式執行top。
-n:與-b配合使用,表示需要進行幾次top命令的輸出結果。-p:指定特定的pid程序號進行觀察。
top -Hp 23344 H 檢視執行緒資訊 P 代表pid

使用後圖示如下:

系統資訊(前五行):

第1行:Top 任務佇列資訊(系統執行狀態及平均負載),與uptime命令結果相同。 
    第1段:系統當前時間,例如:16:07:37
    第2段:系統執行時間,未重啟的時間,時間越長系統越穩定。 
    格式:up xx days, HH:MM
    例如:241 days, 20:11, 表示連續運行了241天20小時11分鐘
    第3段:當前登入使用者數,例如:1 user,表示當前只有1個使用者登入
    第4段:系統負載,即任務佇列的平均長度,3個數值分別統計最近1,5,15分鐘的系統平均負載 
    系統平均負載:單核CPU情況下,0.00 表示沒有任何負荷,1.00表示剛好滿負荷,超過1側表示超負荷,理想值是0.7;
    多核CPU負載:CPU核數 * 理想值0.7 = 理想負荷,例如:4核CPU負載不超過2.8何表示沒有出現高負載。
第2行:Tasks 程序相關資訊 
    第1段:程序總數,例如:Tasks: 231 total, 表示總共執行231個程序
    第2段:正在執行的程序數,例如:1 running,
    第3段:睡眠的程序數,例如:230 sleeping,
    第4段:停止的程序數,例如:0 stopped,
    第5段:殭屍程序數,例如:0 zombie
第3行:Cpus CPU相關資訊,如果是多核CPU,按數字1可顯示各核CPU資訊,此時1行將轉為Cpu核數行,數字1可以來回切換。 
    第1段:us 使用者空間佔用CPU百分比,例如:Cpu(s): 12.7%us,
    第2段:sy 核心空間佔用CPU百分比,例如:8.4%sy,
    第3段:ni 使用者程序空間內改變過優先順序的程序佔用CPU百分比,例如:0.0%ni,
    第4段:id 空閒CPU百分比,例如:77.1%id,
    第5段:wa 等待輸入輸出的CPU時間百分比,例如:0.0%wa,
    第6段:hi CPU服務於硬體中斷所耗費的時間總額,例如:0.0%hi,
    第7段:si CPU服務軟中斷所耗費的時間總額,例如:1.8%si,
    第8段:st Steal time 虛擬機器被hypervisor偷去的CPU時間(如果當前處於一個hypervisor下的vm,實際上hypervisor也是要消耗一部分CPU處理時間的)
第4行:Mem 記憶體相關資訊(Mem: 12196436k total, 12056552k used, 139884k free, 64564k buffers) 
    第1段:實體記憶體總量,例如:Mem: 12196436k total,
    第2段:使用的實體記憶體總量,例如:12056552k used,
    第3段:空閒記憶體總量,例如:Mem: 139884k free,
    第4段:用作核心快取的記憶體量,例如:64564k buffers
 第5行:Swap 交換分割槽相關資訊(Swap: 2097144k total, 151016k used, 1946128k free, 3120236k cached) 
    第1段:交換區總量,例如:Swap: 2097144k total,
    第2段:使用的交換區總量,例如:151016k used,
    第3段:空閒交換區總量,例如:1946128k free,
    第4段:緩衝的交換區總量,3120236k cached

在top命令中按f按可以檢視顯示的列資訊,按對應字母來開啟/關閉列,大寫字母表示開啟,小寫字母表示關閉。帶*號的是預設列。
(資料預設是按CPU使用總量進行排序)

A: PID = (Process Id) 程序Id;  (重點)
E: USER = (User Name) 程序所有者的使用者名稱;
H: PR = (Priority) 優先順序
I: NI = (Nice value) nice值。負值表示高優先順序,正值表示低優先順序
O: VIRT = (Virtual Image (kb)) 程序使用的虛擬記憶體總量,單位kb。VIRT=SWAP+RES  (重點)
Q: RES = (Resident size (kb)) 程序使用的、未被換出的實體記憶體大小,單位kb。RES=CODE+DATA
T: SHR = (Shared Mem size (kb)) 共享記憶體大小,單位kb
W: S = (Process Status) 程序狀態。D=不可中斷的睡眠狀態,R=執行,S=睡眠,T=跟蹤/停止,Z=殭屍程序
K: %CPU = (CPU usage) 上次更新到現在的CPU時間佔用百分比 (重點)
N: %MEM = (Memory usage (RES)) 程序使用的實體記憶體百分比  (重點)
M: TIME+ = (CPU Time, hundredths) 程序使用的CPU時間總計,單位1/100秒 
b: PPID = (Parent Process Pid) 父程序Id 
c: RUSER = (Real user name) 
d: UID = (User Id) 程序所有者的使用者id 
f: GROUP = (Group Name) 程序所有者的組名 
g: TTY = (Controlling Tty) 啟動程序的終端名。不是從終端啟動的程序則顯示為 ? 
j: P = (Last used cpu (SMP)) 最後使用的CPU,僅在多CPU環境下有意義 
p: SWAP = (Swapped size (kb)) 程序使用的虛擬記憶體中,被換出的大小,單位kb 
l: TIME = (CPU Time) 程序使用的CPU時間總計,單位秒 
r: CODE = (Code size (kb)) 可執行程式碼佔用的實體記憶體大小,單位kb 
s: DATA = (Data+Stack size (kb)) 可執行程式碼以外的部分(資料段+棧)佔用的實體記憶體大小,單位kb 
u: nFLT = (Page Fault count) 頁面錯誤次數 
v: nDRT = (Dirty Pages count) 最後一次寫入到現在,被修改過的頁面數 
y: WCHAN = (Sleeping in Function) 若該程序在睡眠,則顯示睡眠中的系統函式名 
z: Flags = (Task Flags <sched.h>) 任務標誌,參考 sched.h
X: COMMAND = (Command name/line) 命令名/命令列

2.瞭解cpu的使用情況

vmstat

一般只看procs與cpu部分

procs:

  • r:執行和等待CPU時間片的程序數,一般來說整個系統的執行佇列不要超過總核數的兩倍,不然系統壓力太大了。
  • b:等待資源的程序數,比如正在等待磁碟IO,網路IO等。
    cpu:
  • us:使用者程序消耗CPU時間百分比,us值高的話,說明使用者程序消耗CPU的時間比較長,如果長期大於50%的話,那就說明程式還有需要優化的地方。
  • sy:核心程序消耗的CPU時間百分比
  • us + sy參考值為80%,如果大於80%的話,說明可能存在CPU不足。

free
檢視記憶體使用情況用free命令,它主要有三個命令,free、free -g、free -m,
推薦使用free -m,如果應用程式可用記憶體/系統實體記憶體大於70%的話,證明記憶體充足,
如果小於20%的話,就要考慮增加記憶體了。

df(disk free)
-h或--human-readable 以可讀性較高的方式來顯示資訊。

檢視磁碟空間用df 或者 df -h這兩個命令。

iostat
檢視磁碟io情況使用iostat,如果提示:-bash:iostat:command not found,
那是因為沒有安裝sysstat,安裝一下就可以了:yum install -y sysstat
接下來執行命令:iostat -xdk 3 2,和vmstat命令很像。

只需要看這些指標就行了:

  • rkb/s 每秒讀取資料量kb;
  • wkb/s: 每秒寫入資料量kb;
  • svctm:I/O請求的平均服務時間,單位毫秒;
  • util:一秒中有百分之幾的時間用於I/O操作,如果接近100%說明磁碟頻寬跑滿了,這個時間就要優化程式或者增加磁碟了。

網路IO命令:sar
通過sar -n DEV 3 2來檢視

  • IFACE:LAN介面
  • rxpck/s:每秒鐘接收的資料包
  • txpck/s:每秒鐘傳送的資料包
  • rxKB/s:每秒接收的資料量,單位KByte
  • txKB/s:每秒發出的資料量,單位KByte
  • rxcmp/s:每秒鐘傳送的壓縮資料包
  • txcmp/s:每秒鐘傳送的壓縮資料包
  • rxmcst/s:每秒鐘接收的多播資料包

ps
顯示程序資訊

netstat
顯示網路情況