2013年9月28日 星期六

每天一個Linux指令- top指令(系統效能分析工具)

每天一個Linux指令- top指令(系統效能分析工具)



拷貝來源:


01.http://www.cnblogs.com/peida/archive/2012/12/05/2803591.html


02.http://www.cnblogs.com/peida/archive/2012/12/24/2831353.html


top命令是Linux下常用的效能分析工具,能夠即時顯示系統中各個進程的資源佔用狀況,類似於Windows的任務管理器。下面詳細介紹它的使用方法。top是一個動態顯示過程,即可以通過用戶按鍵來不斷刷新當前狀態.如果在前臺執行該命令,它將獨佔前臺,直到用戶終止該程式為止.比較準確的說,top命令提供了即時的對系統處理器的狀態監視.它將顯示系統中CPU最“敏感”的任務列表.該命令可以按CPU使用.記憶體使用和執行時間對任務進行排序;而且該命令的很多特性都可以通過互動式命令或者在個人定制檔中進行設定.


1命令格式:


top [參數]


2命令功能:


顯示當前系統正在執行的進程的相關資訊,包括進程ID、記憶體佔用率、CPU佔用率等


3命令參數:


-b 批次處理


-c 顯示完整的治命令


-I 忽略失效過程


-s 保密模式


-S 累積模式


-i<時間> 設置間隔時間


-u<用戶名> 指定用戶名


-p<進程號> 指定進程


-n<次數> 迴圈顯示的次數


4使用實例:


實例1:顯示進程資訊


命令:top


輸出:


[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 命令的執行結果,具體參數說明情況如下:


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 — 任務(進程),具體資訊說明如下:


系統現在共有206個進程,其中處於運行中的有1個,205個在休眠(sleep),stoped狀態的有0個,zombie狀態(僵屍)的有0個。


第三行,cpu狀態資訊,具體屬性說明如下:


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的百分比


備註:在這裏CPU的使用比率和windows概念不同,需要理解linux系統用戶空間和內核空間的相關知識!


第四行,記憶體狀態,具體資訊如下:


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的資料交換,這是真正的記憶體不夠用了。


第六行,空行。


第七行以下:各進程(任務)的狀態監控,專案列資訊說明如下:


PID — 進程id


USER — 進程所有者


PR — 進程優先順序


NI — nice值。負值表示高優先順序,正值表示低優先順序


VIRT — 進程使用的虛擬記憶體總量,單位kb。VIRT=SWAP+RES


RES — 進程使用的、未被換出的實體記憶體大小,單位kb。RES=CODE+DATA


SHR — 共用記憶體大小,單位kb


— 進程狀態。D=不可中斷的睡眠狀態 R=運行 S=睡眠 T=跟蹤/停止 Z=僵屍進程


%CPU — 上次更新到現在的CPU時間佔用百分比


%MEM — 進程使用的實體記憶體百分比


TIME+ — 進程使用的CPU時間總計,單位1/100秒


COMMAND — 進程名稱(命令名/命令行)


 


其他使用技巧:


1.多U多核CPU監控


在top基本視圖中,按鍵盤數位“1”,可監控每個邏輯CPU的狀況


再按數位鍵1,就會返回到top基本視圖介面


2.高亮顯示當前運行進程


  敲擊鍵盤“b”(打開/關閉加亮效果),top的視圖變化如下:


3.進程欄位排序


默認進入top時,各進程是按照CPU的占用量來排序的


4. 通過”shift + >””shift + <”可以向右或左改變排序列


實例2:顯示 完整命令


命令:top –c


實例3:以批次處理模式顯示程式資訊


命令:top -b


實例4:以累積模式顯示程式資訊


命令:top -S


實例5:設置資訊更新次數


命令:top -n 2


說明:表示更新兩次後終止更新顯示


實例6:設置資訊更新時間


命令:top -d 3


說明:表示更新週期為3秒


實例7:顯示指定的進程資訊


命令:top -p 574


5.top交互命令


在top 命令執行過程中可以使用的一些交互命令。這些命令都是單字母的,如果在命令行中使用了s 選項, 其中一些命令可能會被遮罩。


顯示幫助畫面,給出一些簡短的命令總結說明


終止一個進程。


忽略閒置和僵死進程。這是一個開關式命令。


退出程式


重新安排一個進程的優先順序別


切換到累計模式


改變兩次刷新之間的延遲時間(單位為s),如果有小數,就換算成m s。輸入0值則系統將不斷刷新,預設值是5 s


f或者F 從當前顯示中添加或者刪除專案


o或者O 改變顯示專案的順序


切換顯示平均負載和啟動時間資訊


切換顯示記憶體資訊


切換顯示進程和CPU狀態資訊


切換顯示命令名稱和完整命令行


根據駐留記憶體大小進行排序


根據CPU使用百分比大小進行排序


根據時間/累計時間進行排序


  將當前設置寫入~/.toprc文件中 


 




1 則留言:

  1. 實例1中有提到top可以看系統存活時間

    回覆刪除