top命令是Linux下常用的效能分析工具,能夠實時顯示系統中各個程式的資源佔用狀況,類似於Windows的工作管理員。下面詳細介紹它的使用方法。top是一個動態顯示過程,即可以通過使用者按鍵來不斷重新整理當前狀態.如果在前臺執行該命令,它將獨佔前臺,直到使用者終止該程式為止.比較準確的說,top命令提供了實時的對系統處理器的狀態監視.它將顯示系統中CPU最“敏感”的任務列表.該命令可以按CPU使用.記憶體使用和執行時間對任務進行排序;而且該命令的很多特性都可以通過互動式命令或者在個人定製檔案中進行設定.
1.命令格式:
1 |
top [引數] |
2.命令功能:
顯示當前系統正在執行的程式的相關資訊,包括程式ID、記憶體佔用率、CPU佔用率等
3.命令引數:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
-b 批處理 -c 顯示完整的治命令 -I 忽略失效過程 -s 保密模式 -S 累積模式 -i<時間> 設定間隔時間 -u<使用者名稱> 指定使用者名稱 -p<程式號> 指定程式 -n<次數> 迴圈顯示的次數 |
4.使用例項:
例項1:顯示程式資訊
命令:
1 |
top |
輸出:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 |
[root@TG1704 log]# top top - 14:06:23 up 70 days, 16:44, 2 users, load average: 1.25, 1.32, 1.35 Tasks: 206 total, 1 running, 205 sleeping, 0 stopped, 0 zombie Cpu(s): 5.9%us, 3.4%sy, 0.0%ni, 90.4%id, 0.0%wa, 0.0%hi, 0.2%si, 0.0%st Mem: 32949016k total, 14411180k used, 18537836k free, 169884k buffers Swap: 32764556k total, 0k used, 32764556k free, 3612636k cached PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 28894 root 22 0 1501m 405m 10m S 52.2 1.3 2534:16 java 18249 root 18 0 3201m 1.9g 11m S 35.9 6.0 569:39.41 java 2808 root 25 0 3333m 1.0g 11m S 24.3 3.1 526:51.85 java 25668 root 23 0 3180m 704m 11m S 14.0 2.2 360:44.53 java 574 root 25 0 3168m 611m 10m S 12.6 1.9 556:59.63 java 1599 root 20 0 3237m 1.9g 11m S 12.3 6.2 262:01.14 java 1008 root 21 0 3147m 842m 10m S 0.3 2.6 4:31.08 java 13823 root 23 0 3031m 2.1g 10m S 0.3 6.8 176:57.34 java 28218 root 15 0 12760 1168 808 R 0.3 0.0 0:01.43 top 29062 root 20 0 1241m 227m 10m S 0.3 0.7 2:07.32 java 1 root 15 0 10368 684 572 S 0.0 0.0 1:30.85 init 2 root RT -5 0 0 0 S 0.0 0.0 0:01.01 migration/0 3 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0 4 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/0 5 root RT -5 0 0 0 S 0.0 0.0 0:00.80 migration/1 6 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/1 7 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/1 8 root RT -5 0 0 0 S 0.0 0.0 0:20.59 migration/2 9 root 34 19 0 0 0 S 0.0 0.0 0:00.09 ksoftirqd/2 10 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/2 11 root RT -5 0 0 0 S 0.0 0.0 0:23.66 migration/3 12 root 34 19 0 0 0 S 0.0 0.0 0:00.03 ksoftirqd/3 13 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/3 14 root RT -5 0 0 0 S 0.0 0.0 0:20.29 migration/4 15 root 34 19 0 0 0 S 0.0 0.0 0:00.07 ksoftirqd/4 16 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/4 17 root RT -5 0 0 0 S 0.0 0.0 0:23.07 migration/5 18 root 34 19 0 0 0 S 0.0 0.0 0:00.07 ksoftirqd/5 19 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/5 20 root RT -5 0 0 0 S 0.0 0.0 0:17.16 migration/6 21 root 34 19 0 0 0 S 0.0 0.0 0:00.05 ksoftirqd/6 22 root RT -5 0 0 0 S 0.0 0.0 0:00.00 watchdog/6 23 root RT -5 0 0 0 S 0.0 0.0 0:58.28 migration/7 |
說明:
統計資訊區:
前五行是當前系統情況整體的統計資訊區。下面我們看每一行資訊的具體意義。
第一行,任務佇列資訊,同 uptime 命令的執行結果,具體引數說明情況如下:
1 2 3 4 5 |
14:06:23 — 當前系統時間 up 70 days, 16:44 — 系統已經執行了70天16小時44分鐘(在這期間系統沒有重啟過的吆!) 2 users — 當前有2個使用者登入系統 load average: 1.15, 1.42, 1.44 — load average後面的三個數分別是1分鐘、5分鐘、15分鐘的負載情況。 load average資料是每隔5秒鐘檢查一次活躍的程式數,然後按特定演算法計算出的數值。如果這個數除以邏輯CPU的數量,結果高於5的時候就表明系統在超負荷運轉了。 |
第二行,Tasks — 任務(程式),具體資訊說明如下:
1 |
系統現在共有206個程式,其中處於執行中的有1個,205個在休眠(sleep),stoped狀態的有0個,zombie狀態(殭屍)的有0個。 |
第三行,cpu狀態資訊,具體屬性說明如下:
1 2 3 4 5 6 7 |
5.9%us — 使用者空間佔用CPU的百分比。 3.4% sy — 核心空間佔用CPU的百分比。 0.0% ni — 改變過優先順序的程式佔用CPU的百分比 90.4% id — 空閒CPU百分比 0.0% wa — IO等待佔用CPU的百分比 0.0% hi — 硬中斷(Hardware IRQ)佔用CPU的百分比 0.2% si — 軟中斷(Software Interrupts)佔用CPU的百分比 |
第四行,記憶體狀態,具體資訊如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
32949016k total — 實體記憶體總量(32GB) 14411180k used — 使用中的記憶體總量(14GB) 18537836k free — 空閒記憶體總量(18GB) 169884k buffers — 快取的記憶體量 (169M) 第五行,swap交換分割槽資訊,具體資訊說明如下: 32764556k total — 交換區總量(32GB) 0k used — 使用的交換區總量(0K) 32764556k free — 空閒交換區總量(32GB) 3612636k cached — 緩衝的交換區總量(3.6GB) |
備註:
第四行中使用中的記憶體總量(used)指的是現在系統核心控制的記憶體數,空閒記憶體總量(free)是核心還未納入其管控範圍的數量。納入核心管理的記憶體不見得都在使用中,還包括過去使用過的現在可以被重複利用的記憶體,核心並不把這些可被重新使用的記憶體交還到free中去,因此在linux上free記憶體會越來越少,但不用為此擔心。
如果出於習慣去計算可用記憶體數,這裡有個近似的計算公式:第四行的free + 第四行的buffers + 第五行的cached,按這個公式此臺伺服器的可用記憶體:18537836k +169884k +3612636k = 22GB左右。
對於記憶體監控,在top裡我們要時刻監控第五行swap交換分割槽的used,如果這個數值在不斷的變化,說明核心在不斷進行記憶體和swap的資料交換,這是真正的記憶體不夠用了。
第六行,空行。
第七行以下:各程式(任務)的狀態監控,專案列資訊說明如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
PID — 程式id USER — 程式所有者 PR — 程式優先順序 NI — nice值。負值表示高優先順序,正值表示低優先順序 VIRT — 程式使用的虛擬記憶體總量,單位kb。VIRT=SWAP+RES RES — 程式使用的、未被換出的實體記憶體大小,單位kb。RES=CODE+DATA SHR — 共享記憶體大小,單位kb S — 程式狀態。D=不可中斷的睡眠狀態 R=執行 S=睡眠 T=跟蹤/停止 Z=殭屍程式 %CPU — 上次更新到現在的CPU時間佔用百分比 %MEM — 程式使用的實體記憶體百分比 TIME+ — 程式使用的CPU時間總計,單位1/100秒 COMMAND — 程式名稱(命令名/命令列) |
其他使用技巧:
1.多U多核CPU監控
在top基本檢視中,按鍵盤數字“1”,可監控每個邏輯CPU的狀況:
觀察上圖,伺服器有16個邏輯CPU,實際上是4個物理CPU。再按數字鍵1,就會返回到top基本檢視介面。
2.高亮顯示當前執行程式
敲擊鍵盤“b”(開啟/關閉加亮效果),top的檢視變化如下:
我們發現程式id為2570的“top”程式被加亮了,top程式就是檢視第二行顯示的唯一的執行態(runing)的那個程式,可以通過敲擊“y”鍵關閉或開啟執行態程式的加亮效果。
3.程式欄位排序
預設進入top時,各程式是按照CPU的佔用量來排序的,在下圖中程式ID為28894的java程式排在第一(cpu佔用142%),程式ID為574的java程式排在第二(cpu佔用16%)。
敲擊鍵盤“x”(開啟/關閉排序列的加亮效果),top的檢視變化如下:
可以看到,top預設的排序列是“%CPU”。
4. 通過”shift + >”或”shift + <”可以向右或左改變排序列
下圖是按一次”shift + >”的效果圖,檢視現在已經按照%MEM來排序。
例項2:顯示 完整命令
命令:
1 |
top -c |
輸出:
說明:
例項3:以批處理模式顯示程式資訊
命令:
1 |
top -b |
輸出:
說明:
例項4:以累積模式顯示程式資訊
命令:
1 |
top -S |
輸出:
說明:
例項5:設定資訊更新次數
命令:
1 |
top -n 2 |
輸出:
說明:
表示更新兩次後終止更新顯示
例項6:設定資訊更新時間
命令:
1 |
top -d 3 |
輸出:
說明:
表示更新週期為3秒
例項7:顯示指定的程式資訊
命令:
1 |
top -p 574 |
輸出:
說明:
5.top互動命令
在top 命令執行過程中可以使用的一些互動命令。這些命令都是單字母的,如果在命令列中使用了s 選項, 其中一些命令可能會被遮蔽。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
h 顯示幫助畫面,給出一些簡短的命令總結說明 k 終止一個程式。 i 忽略閒置和僵死程式。這是一個開關式命令。 q 退出程式 r 重新安排一個程式的優先順序別 S 切換到累計模式 s 改變兩次重新整理之間的延遲時間(單位為s),如果有小數,就換算成m s。輸入0值則系統將不斷重新整理,預設值是5 s f或者F 從當前顯示中新增或者刪除專案 o或者O 改變顯示專案的順序 l 切換顯示平均負載和啟動時間資訊 m 切換顯示記憶體資訊 t 切換顯示程式和CPU狀態資訊 c 切換顯示命令名稱和完整命令列 M 根據駐留記憶體大小進行排序 P 根據CPU使用百分比大小進行排序 T 根據時間/累計時間進行排序 W 將當前設定寫入~/.toprc檔案中 |
本系列文章:
每天一個 Linux 命令(1):ls命令
每天一個 Linux 命令(2):cd命令
每天一個 Linux 命令(3):pwd命令
每天一個 Linux 命令(4):mkdir命令
每天一個 Linux 命令(5):rm 命令
每天一個 Linux 命令(6):rmdir 命令
每天一個 Linux 命令(7):mv命令
每天一個 Linux 命令(8):cp 命令
每天一個 Linux 命令(9):touch 命令
每天一個 Linux 命令(10):cat 命令
每天一個 Linux 命令(11):nl 命令
每天一個 Linux 命令(12):more 命令
每天一個 Linux 命令(13):less 命令
每天一個 Linux 命令(14):head 命令
每天一個 Linux 命令(15):tail 命令
每天一個 Linux 命令(16):which命令
每天一個 Linux 命令(17):whereis 命令
每天一個 Linux 命令(18):locate 命令
每天一個 Linux 命令(19):find 命令概覽
每天一個 Linux 命令(20):find命令之exec
每天一個 Linux 命令(21):find命令之xargs
每天一個 Linux 命令(22):find 命令的引數詳解
每天一個 Linux 命令(23):Linux 目錄結構
每天一個 Linux 命令(24):Linux 檔案型別與副檔名
每天一個 Linux 命令(25):Linux 檔案屬性詳解
每天一個 Linux 命令(26):用 SecureCRT 來上傳和下載檔案
每天一個 Linux 命令(27):linux chmod 命令
每天一個 Linux 命令(28):tar 命令
每天一個 Linux 命令(29): chgrp 命令
每天一個 Linux 命令(30): chown 命令
每天一個 Linux 命令(31): /etc/group 檔案詳解
每天一個 Linux 命令(32):gzip 命令
每天一個 Linux 命令(33):df 命令
每天一個 Linux 命令(34): du 命令
每天一個 Linux 命令(35): ln 命令
每天一個 Linux 命令(36): diff 命令
每天一個 Linux 命令(37): date 命令
每天一個 Linux 命令(38): cal 命令
每天一個 Linux 命令(39): grep 命令
每天一個 Linux 命令(40): wc 命令
每天一個 Linux 命令(41): ps 命令