首先介紹top中一些字段的含義:
肥東網(wǎng)站建設(shè)公司成都創(chuàng)新互聯(lián),肥東網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為肥東上1000+提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)公司要多少錢,請找那個售后服務(wù)好的肥東做網(wǎng)站的公司定做!
VIRT:virtual memory usage 虛擬內(nèi)存
1、進(jìn)程“需要的”虛擬內(nèi)存大小,包括進(jìn)程使用的庫、代碼、數(shù)據(jù)等
2、假如進(jìn)程申請100m的內(nèi)存,但實(shí)際只使用了10m,那么它會增長100m,而不是實(shí)際的使用量
RES:resident memory usage 常駐內(nèi)存
1、進(jìn)程當(dāng)前使用的內(nèi)存大小,但不包括swap out
2、包含其他進(jìn)程的共享
3、如果申請100m的內(nèi)存,實(shí)際使用10m,它只增長10m,與VIRT相反
4、關(guān)于庫占用內(nèi)存的情況,它只統(tǒng)計(jì)加載的庫文件所占內(nèi)存大小
SHR:shared memory 共享內(nèi)存
1、除了自身進(jìn)程的共享內(nèi)存,也包括其他進(jìn)程的共享內(nèi)存
2、雖然進(jìn)程只使用了幾個共享庫的函數(shù),但它包含了整個共享庫的大小
3、計(jì)算某個進(jìn)程所占的物理內(nèi)存大小公式:RES – SHR
4、swap out后,它將會降下來
DATA
1、數(shù)據(jù)占用的內(nèi)存。如果top沒有顯示,按f鍵可以顯示出來。
2、真正的該程序要求的數(shù)據(jù)空間,是真正在運(yùn)行中要使用的。
top 運(yùn)行中可以通過 top 的內(nèi)部命令對進(jìn)程的顯示方式進(jìn)行控制。內(nèi)部命令如下:
s – 改變畫面更新頻率
l – 關(guān)閉或開啟第一部分第一行 top 信息的表示
t – 關(guān)閉或開啟第一部分第二行 Tasks 和第三行 Cpus 信息的表示
m – 關(guān)閉或開啟第一部分第四行 Mem 和 第五行 Swap 信息的表示
N – 以 PID 的大小的順序排列表示進(jìn)程列表
P – 以 CPU 占用率大小的順序排列進(jìn)程列表
M – 以內(nèi)存占用率大小的順序排列進(jìn)程列表
h – 顯示幫助
n – 設(shè)置在進(jìn)程列表所顯示進(jìn)程的數(shù)量
q – 退出 top
s – 改變畫面更新周期
序號 列名 含義
a PID 進(jìn)程id
b PPID 父進(jìn)程id
c RUSER Real user name
d UID 進(jìn)程所有者的用戶id
e USER 進(jìn)程所有者的用戶名
f GROUP 進(jìn)程所有者的組名
g TTY 啟動進(jìn)程的終端名。不是從終端啟動的進(jìn)程則顯示為 ?
h PR 優(yōu)先級
i NI nice值。負(fù)值表示高優(yōu)先級,正值表示低優(yōu)先級
j P 最后使用的CPU,僅在多CPU環(huán)境下有意義
k %CPU 上次更新到現(xiàn)在的CPU時間占用百分比
l TIME 進(jìn)程使用的CPU時間總計(jì),單位秒
m TIME+ 進(jìn)程使用的CPU時間總計(jì),單位1/100秒
n %MEM 進(jìn)程使用的物理內(nèi)存百分比
o VIRT 進(jìn)程使用的虛擬內(nèi)存總量,單位kb。VIRT=SWAP+RES
p SWAP 進(jìn)程使用的虛擬內(nèi)存中,被換出的大小,單位kb。
q RES 進(jìn)程使用的、未被換出的物理內(nèi)存大小,單位kb。RES=CODE+DATA
r CODE 可執(zhí)行代碼占用的物理內(nèi)存大小,單位kb
s DATA 可執(zhí)行代碼以外的部分(數(shù)據(jù)段+棧)占用的物理內(nèi)存大小,單位kb
t SHR 共享內(nèi)存大小,單位kb
u nFLT 頁面錯誤次數(shù)
v nDRT 最后一次寫入到現(xiàn)在,被修改過的頁面數(shù)。
w S 進(jìn)程狀態(tài)。(D=不可中斷的睡眠狀態(tài),R=運(yùn)行,S=睡眠,T=跟蹤/停止,Z=僵尸進(jìn)程)
x COMMAND 命令名/命令行
y WCHAN 若該進(jìn)程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名
z Flags 任務(wù)標(biāo)志,參考 sched.h
默認(rèn)情況下僅顯示比較重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通過下面的快捷鍵來更改顯示內(nèi)容。
通過 f 鍵可以選擇顯示的內(nèi)容。按 f 鍵之后會顯示列的列表,按 a-z 即可顯示或隱藏對應(yīng)的列,最后按回車鍵確定。
按 o 鍵可以改變列的顯示順序。按小寫的 a-z 可以將相應(yīng)的列向右移動,而大寫的 A-Z 可以將相應(yīng)的列向左移動。最后按回車鍵確定。
按大寫的 F 或 O 鍵,然后按 a-z 可以將進(jìn)程按照相應(yīng)的列進(jìn)行排序。而大寫的 R 鍵可以將當(dāng)前的排序倒轉(zhuǎn)。
top使用方法:
使用格式:
top [-] [d] [p] [q] [c] [C] [S] [s] [n]
參數(shù)說明:
d:指定每兩次屏幕信息刷新之間的時間間隔。當(dāng)然用戶可以使用s交互命令來改變之。
p:通過指定監(jiān)控進(jìn)程ID來僅僅監(jiān)控某個進(jìn)程的狀態(tài)。
q:該選項(xiàng)將使top沒有任何延遲的進(jìn)行刷新。如果調(diào)用程序有超級用戶權(quán)限,那么top將以盡可能高的優(yōu)先級運(yùn)行。
S:指定累計(jì)模式。
s:使top命令在安全模式中運(yùn)行。這將去除交互命令所帶來的潛在危險。
i: 使top不顯示任何閑置或者僵死進(jìn)程。
c: 顯示整個命令行而不只是顯示命令名。
常用命令說明:
Ctrl+L:擦除并且重寫屏幕
K:終止一個進(jìn)程。系統(tǒng)將提示用戶輸入需要終止的進(jìn)程PID,以及需要發(fā)送給該進(jìn)程什么樣的信號。一般的終止進(jìn)程可以使用15信號;如果不能正常結(jié)束那就使用信號9強(qiáng)制結(jié)束該進(jìn)程。默認(rèn)值是信號15。在安全模式中此命令被屏蔽。
i:忽略閑置和僵死進(jìn)程。這是一個開關(guān)式命令。
q:退出程序
r:重新安排一個進(jìn)程的優(yōu)先級別。系統(tǒng)提示用戶輸入需要改變的進(jìn)程PID以及需要設(shè)置的進(jìn)程優(yōu)先級值。輸入一個正值將使優(yōu)先級降低,反之則可以使該進(jìn)程擁有更高的優(yōu)先權(quán)。默認(rèn)值是10。
S:切換到累計(jì)模式。
s:改變兩次刷新之間的延遲時間。系統(tǒng)將提示用戶輸入新的時間,單位為s。如果有小數(shù),就換算成m s。輸入0值則系統(tǒng)將不斷刷新,默認(rèn)值是5 s。需要注意的是如果設(shè)置太小的時間,很可能會引起不斷刷新,從而根本來不及看清顯示的情況,而且系統(tǒng)負(fù)載也會大大增加。
f或者F:從當(dāng)前顯示中添加或者刪除項(xiàng)目。
o或者O:改變顯示項(xiàng)目的順序
l:切換顯示平均負(fù)載和啟動時間信息。
m:切換顯示內(nèi)存信息。
t:切換顯示進(jìn)程和CPU狀態(tài)信息。
c:切換顯示命令名稱和完整命令行。
M:根據(jù)駐留內(nèi)存大小進(jìn)行排序。
P:根據(jù)CPU使用百分比大小進(jìn)行排序。
T:根據(jù)時間/累計(jì)時間進(jìn)行排序。
W:將當(dāng)前設(shè)置寫入~/.toprc文件中。
提升你top命令的知識
嘗試找出你的機(jī)器正在運(yùn)行什么程序,以及哪個進(jìn)程耗盡了內(nèi)存導(dǎo)致系統(tǒng)非常非常慢 —— 這是 top 命令所能勝任的工作。
top 是一個非常有用的程序,其作用類似于 Windows 任務(wù)管理器或 MacOS 的活動監(jiān)視器。在 *nix 機(jī)器上運(yùn)行 top 將實(shí)時顯示系統(tǒng)上運(yùn)行的進(jìn)程的情況。
$ top
取決于你運(yùn)行的 top 版本,你會看到類似如下內(nèi)容:
top - 08:31:32 up 1 day, 4:09, 0 users, load average: 0.20, 0.12, 0.10 Tasks: 3 total, 1 running, 2 sleeping, 0 stopped, 0 zombie %Cpu(s): 0.5 us, 0.3 sy, 0.0 ni, 99.2 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st KiB Mem: 4042284 total, 2523744 used, 1518540 free, 263776 buffers KiB Swap: 1048572 total, 0 used, 1048572 free. 1804264 cached Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND 1 root 20 0 21964 3632 3124 S 0.0 0.1 0:00.23 bash 193 root 20 0 123520 29636 8640 S 0.0 0.7 0:00.58 flask 195 root 20 0 23608 2724 2400 R 0.0 0.1 0:00.21 top
你所用的 top 版本可能跟這個看起來不一樣,特別是在顯示的列上。
如何閱讀輸出的內(nèi)容
你可以根據(jù)輸出判斷你正在運(yùn)行的內(nèi)容,但嘗試去解釋結(jié)果你可能會有些困惑。
前幾行包含一堆統(tǒng)計(jì)信息(詳細(xì)信息),后跟一個包含結(jié)果列的表(列)。讓我們從后者開始吧。
列
這些是系統(tǒng)正在運(yùn)行的進(jìn)程。默認(rèn)按 CPU 使用率降序排序。這意味著在列表頂部的程序正使用更多的 CPU 資源并對你的系統(tǒng)造成更重的負(fù)擔(dān)。對于資源使用而言,這些程序是字面上的消耗資源最多的(top)進(jìn)程。不得不說,top 這個名字起得很妙。
最右邊的 COMMAND 一列報告進(jìn)程名(啟動它們的命令)。在這個例子里,進(jìn)程名是 bash(一個我們正在運(yùn)行 top 的命令解釋器)、flask(一個 Python 寫的 web 框架)和 top 自身。
其它列提供了關(guān)于進(jìn)程的有用信息:
確切知道 VIRT,RES 和 SHR 值代表什么在日常操作中并不重要。重要的是要知道 VIRT 值最高的進(jìn)程就是內(nèi)存使用最多的進(jìn)程。當(dāng)你在用 top 排查為什么你的電腦運(yùn)行無比卡的時候,那個 VIRT 數(shù)值最大的進(jìn)程就是元兇。如果你想要知道共享內(nèi)存和物理內(nèi)存的確切意思,請查閱 top 手冊 的 Linux Memory Types 段落。
是的,我說的是 kibibytes 而不是 kilobytes。通常稱為 kilobyte 的 1024 值實(shí)際上是 kibibyte。希臘語的 kilo(χίλιοι)意思是一千(例如一千米是 1000 米,一千克是 1000 克)。Kibi 是 kilo 和 binary 的合成詞,意思是 1024 字節(jié)(或者 2^10 )。但是,因?yàn)檫@個詞很難說,所以很多人在說 1024 字節(jié)的時候會說 kilobyte。top 試圖在這里使用恰當(dāng)?shù)男g(shù)語,所以按它說的理解就好。
屏幕更新說明
實(shí)時屏幕更新是 Linux 程序可以做的 非???的事之一。這意味著程序能實(shí)時更新它們顯示的內(nèi)容,所以看起來是動態(tài)的,即使它們用的是文本。非???!在我們的例子中,更新時間間隔很重要,因?yàn)橐恍┙y(tǒng)計(jì)數(shù)據(jù)(%CPU 和 %MEM)是基于上次屏幕更新的數(shù)值的。
因?yàn)槲覀冞\(yùn)行在一個持久性的程序中,我們就可以輸入一些命令來實(shí)時修改配置(而不是停止應(yīng)用,然后用一個不同的命令行選項(xiàng)再次運(yùn)行)。
按下 h 調(diào)用幫助界面,該界面也顯示了默認(rèn)延遲(屏幕更新的時間間隔)。這個值默認(rèn)(大約)是 3 秒,但你可以輸入 d(大概是 delay 的意思)或者 s(可能是 screen 或 seconds 的意思)來修改它。
細(xì)節(jié)
在進(jìn)程列表上面有一大堆有用的信息。有些細(xì)節(jié)看起來有點(diǎn)兒奇怪,讓人困惑。但是一旦你花點(diǎn)兒時間來逐個過一遍,你會發(fā)現(xiàn),在緊要關(guān)頭,這些是非常有用的。
第一行包含系統(tǒng)的大致信息:
第二行(Task)顯示了正在運(yùn)行的任務(wù)的信息,不用解釋。它顯示了進(jìn)程總數(shù)和正在運(yùn)行的、休眠中的、停止的進(jìn)程數(shù)和僵尸進(jìn)程數(shù)。這實(shí)際上是上述 S(狀態(tài))列的總和。
第三行(%Cpu(s))顯示了按類型劃分的 CPU 使用情況。數(shù)據(jù)是屏幕刷新之間的值。這些值是:
你可以通過點(diǎn)擊 t(toggle)來展開或折疊 Task 和 %Cpu(s) 行。
第四行(Kib Mem)和第五行(KiB Swap)提供了內(nèi)存和交換空間的信息。這些數(shù)值是:
默認(rèn)它們是用 KiB 為單位展示的,但是按下 E(擴(kuò)展內(nèi)存縮放 extend memory scaling)可以輪換不同的單位:KiB、MiB、GiB、TiB、PiB、EiB(kilobytes、megabytes、gigabytes、terabytes、petabytes 和 exabytes)
top 用戶手冊有更多選項(xiàng)和配置項(xiàng)信息。你可以運(yùn)行 man top 來查看你系統(tǒng)上的文檔。還有很多 HTML 版的 man 手冊 ,但是請留意,這些手冊可能是針對不同 top 版本的。
兩個 top 的替代品
你不必總是用 top 查看系統(tǒng)狀態(tài)。你可以根據(jù)你的情況用其它工具來協(xié)助排查問題,尤其是當(dāng)你想要更圖形化或更專業(yè)的界面的時候。
htop
htop 很像 top,但是它帶來了一些非常有用的東西:它可以以圖形界面展示 CPU 和內(nèi)存使用情況。
這是我們在剛才運(yùn)行 top 的同一環(huán)境中 htop 的樣子。顯示更簡潔,但功能卻很豐富。
任務(wù)統(tǒng)計(jì)、負(fù)載、uptime 和進(jìn)程列表仍然在,但是它有了漂亮、彩色、動態(tài)的每核 CPU 使用情況,還有圖形化的內(nèi)存使用情況。
以下是不同顏色的含義(你也可以通過按下 h 來獲得這些信息的幫助)。
CPU 任務(wù)優(yōu)先級或類型:
內(nèi)存:
如果顏色對你沒用,你可以運(yùn)行 htop -C 來禁用它們;那樣 htop 將使用不同的符號來展示 CPU 和內(nèi)存類型。
它的底部有一組激活的快捷鍵提示,可以用來操作過濾結(jié)果或改變排序順序。試著按一些快捷鍵看看它們能做什么。不過嘗試 F9 時要小心,它會調(diào)出一個信號列表,這些信號會殺死(即停止)一個過程。我建議在生產(chǎn)環(huán)境之外探索這些選項(xiàng)。
htop 的作者 Hisham Muhammad(是的,htop 的名字就是源自 Hisham 的)在二月份的 FOSDEM 2018 做了一個 簡短的演講 。他闡述了 htop 不僅有簡潔的圖形界面,還有更現(xiàn)代的進(jìn)程信息統(tǒng)計(jì)展示方式,這都是之前的工具(如 top)所不具備的。
你可以在 手冊頁面 或 htop 網(wǎng)站 閱讀更多關(guān)于 htop 的信息。(提示:網(wǎng)站背景是一個動態(tài)的 htop。)
docker stats
如果你在用Docker,你可以運(yùn)行 docker stats 來為容器狀態(tài)生成一個有豐富上下文的界面。
這可能比 top 更有幫助,因?yàn)樗皇前催M(jìn)程分類,而是按容器分類的。這點(diǎn)特別有用,當(dāng)某個容器運(yùn)行緩慢時,查看哪個容器耗資源最多比運(yùn)行 top 再找到容器的進(jìn)程要快。
借助于上面對top和htop術(shù)語的解釋,你應(yīng)該會更容易理解docker stats 中的那些。然而,docker stats 文檔 對每一列都提供了詳盡的描述。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對創(chuàng)新互聯(lián)的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
網(wǎng)頁標(biāo)題:Linux中使用top命令的技巧
文章起源:http://aaarwkj.com/article34/gooope.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站、品牌網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)公司、Google、靜態(tài)網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)