91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linux中使用top命令的技巧

發布時間:2020-08-25 13:43:31 來源:腳本之家 閱讀:141 作者:Katie Mclaughlin 欄目:服務器

首先介紹top中一些字段的含義:

 VIRT:virtual memory usage 虛擬內存

1、進程“需要的”虛擬內存大小,包括進程使用的庫、代碼、數據等
2、假如進程申請100m的內存,但實際只使用了10m,那么它會增長100m,而不是實際的使用量

RES:resident memory usage 常駐內存

1、進程當前使用的內存大小,但不包括swap out
2、包含其他進程的共享
3、如果申請100m的內存,實際使用10m,它只增長10m,與VIRT相反
4、關于庫占用內存的情況,它只統計加載的庫文件所占內存大小

SHR:shared memory 共享內存

1、除了自身進程的共享內存,也包括其他進程的共享內存
2、雖然進程只使用了幾個共享庫的函數,但它包含了整個共享庫的大小
3、計算某個進程所占的物理內存大小公式:RES – SHR
4、swap out后,它將會降下來

DATA

1、數據占用的內存。如果top沒有顯示,按f鍵可以顯示出來。
2、真正的該程序要求的數據空間,是真正在運行中要使用的。

top 運行中可以通過 top 的內部命令對進程的顯示方式進行控制。內部命令如下:

s – 改變畫面更新頻率
l – 關閉或開啟第一部分第一行 top 信息的表示
t – 關閉或開啟第一部分第二行 Tasks 和第三行 Cpus 信息的表示
m – 關閉或開啟第一部分第四行 Mem 和 第五行 Swap 信息的表示
N – 以 PID 的大小的順序排列表示進程列表
P – 以 CPU 占用率大小的順序排列進程列表
M – 以內存占用率大小的順序排列進程列表
h – 顯示幫助
n – 設置在進程列表所顯示進程的數量
q – 退出 top
s – 改變畫面更新周期

序號 列名 含義

a PID   進程id
b PPID 父進程id
c RUSER Real user name
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

默認情況下僅顯示比較重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND 列。可以通過下面的快捷鍵來更改顯示內容。

通過 f 鍵可以選擇顯示的內容。按 f 鍵之后會顯示列的列表,按 a-z 即可顯示或隱藏對應的列,最后按回車鍵確定。
按 o 鍵可以改變列的顯示順序。按小寫的 a-z 可以將相應的列向右移動,而大寫的 A-Z 可以將相應的列向左移動。最后按回車鍵確定。
按大寫的 F 或 O 鍵,然后按 a-z 可以將進程按照相應的列進行排序。而大寫的 R 鍵可以將當前的排序倒轉。

top使用方法:

使用格式:

top [-] [d] [p] [q] [c] [C] [S] [s] [n]

參數說明:

d:指定每兩次屏幕信息刷新之間的時間間隔。當然用戶可以使用s交互命令來改變之。

p:通過指定監控進程ID來僅僅監控某個進程的狀態。

q:該選項將使top沒有任何延遲的進行刷新。如果調用程序有超級用戶權限,那么top將以盡可能高的優先級運行。

S:指定累計模式。

s:使top命令在安全模式中運行。這將去除交互命令所帶來的潛在危險。

i: 使top不顯示任何閑置或者僵死進程。

c: 顯示整個命令行而不只是顯示命令名。

常用命令說明:

Ctrl+L:擦除并且重寫屏幕

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命令的知識

嘗試找出你的機器正在運行什么程序,以及哪個進程耗盡了內存導致系統非常非常慢 —— 這是 top 命令所能勝任的工作。

top 是一個非常有用的程序,其作用類似于 Windows 任務管理器或 MacOS 的活動監視器。在 *nix 機器上運行 top 將實時顯示系統上運行的進程的情況。

$ top

取決于你運行的 top 版本,你會看到類似如下內容:

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 版本可能跟這個看起來不一樣,特別是在顯示的列上。

如何閱讀輸出的內容

你可以根據輸出判斷你正在運行的內容,但嘗試去解釋結果你可能會有些困惑。

前幾行包含一堆統計信息(詳細信息),后跟一個包含結果列的表(列)。讓我們從后者開始吧。


這些是系統正在運行的進程。默認按 CPU 使用率降序排序。這意味著在列表頂部的程序正使用更多的 CPU 資源并對你的系統造成更重的負擔。對于資源使用而言,這些程序是字面上的消耗資源最多的(top)進程。不得不說,top 這個名字起得很妙。

最右邊的 COMMAND 一列報告進程名(啟動它們的命令)。在這個例子里,進程名是 bash(一個我們正在運行 top 的命令解釋器)、flask(一個 Python 寫的 web 框架)和 top 自身。

其它列提供了關于進程的有用信息:

  • PID:進程 ID,一個用來定位進程的唯一標識符
  • USER:運行進程的用戶
  • PR:任務的優先級
  • NI:Nice 值,優先級的一個更好的表現形式
  • VIRT:虛擬內存的大小,單位是 KiB(kibibytes)
  • RES:常駐內存大小,單位是 KiB(物理內存和虛擬內存的一部分)
  • SHR:共享內存大小,單位是 KiB(共享內存和虛擬內存的一部分)
  • S:進程狀態,一般 I 代表空閑,R 代表運行,S 代表休眠,Z 代表僵尸進程,T 或 t 代表停止(還有其它更少見的選項)
  • %CPU:自從上次屏幕更新后的 CPU 使用率
  • %MEM:自從上次屏幕更新后的 RES 常駐內存使用率
  • TIME+:自從程序啟動后總的 CPU 使用時間
  • COMMAND:啟動命令,如之前描述那樣

確切知道 VIRT,RES 和 SHR 值代表什么在日常操作中并不重要。重要的是要知道 VIRT 值最高的進程就是內存使用最多的進程。當你在用 top 排查為什么你的電腦運行無比卡的時候,那個 VIRT 數值最大的進程就是元兇。如果你想要知道共享內存和物理內存的確切意思,請查閱 top 手冊 的 Linux Memory Types 段落。

是的,我說的是 kibibytes 而不是 kilobytes。通常稱為 kilobyte 的 1024 值實際上是 kibibyte。希臘語的 kilo(χίλιοι)意思是一千(例如一千米是 1000 米,一千克是 1000 克)。Kibi 是 kilo 和 binary 的合成詞,意思是 1024 字節(或者 2^10 )。但是,因為這個詞很難說,所以很多人在說 1024 字節的時候會說 kilobyte。top 試圖在這里使用恰當的術語,所以按它說的理解就好。

屏幕更新說明

實時屏幕更新是 Linux 程序可以做的 非常酷 的事之一。這意味著程序能實時更新它們顯示的內容,所以看起來是動態的,即使它們用的是文本。非常酷!在我們的例子中,更新時間間隔很重要,因為一些統計數據(%CPU 和 %MEM)是基于上次屏幕更新的數值的。

因為我們運行在一個持久性的程序中,我們就可以輸入一些命令來實時修改配置(而不是停止應用,然后用一個不同的命令行選項再次運行)。

按下 h 調用幫助界面,該界面也顯示了默認延遲(屏幕更新的時間間隔)。這個值默認(大約)是 3 秒,但你可以輸入 d(大概是 delay 的意思)或者 s(可能是 screen 或 seconds 的意思)來修改它。

細節

在進程列表上面有一大堆有用的信息。有些細節看起來有點兒奇怪,讓人困惑。但是一旦你花點兒時間來逐個過一遍,你會發現,在緊要關頭,這些是非常有用的。

第一行包含系統的大致信息:

  • top:我們正在運行 top!你好!top!
  • XX:YY:XX:當前時間,每次屏幕更新的時候更新
  • up(接下去是 X day, YY:ZZ):系統的 uptime ,或者自從系統啟動后已經過去了多長時間
  • load average(后跟三個數字):分別是過去一分鐘、五分鐘、15 分鐘的 系統負載

第二行(Task)顯示了正在運行的任務的信息,不用解釋。它顯示了進程總數和正在運行的、休眠中的、停止的進程數和僵尸進程數。這實際上是上述 S(狀態)列的總和。

第三行(%Cpu(s))顯示了按類型劃分的 CPU 使用情況。數據是屏幕刷新之間的值。這些值是:

  • us:用戶進程
  • sy:系統進程
  • ni: nice 用戶進程
  • id:CPU 的空閑時間,這個值比較高時說明系統比較空閑
  • wa:等待時間,或者消耗在等待 I/O 完成的時間
  • hi:消耗在硬件中斷的時間
  • si:消耗在軟件中斷的時間
  • st:“虛擬機管理程序從該虛擬機竊取的時間”

你可以通過點擊 t(toggle)來展開或折疊 Task 和 %Cpu(s) 行。

第四行(Kib Mem)和第五行(KiB Swap)提供了內存和交換空間的信息。這些數值是:

  • 總內存容量
  • 已用內存
  • 空閑內存
  • 內存的緩沖值
  • 交換空間的緩存值

默認它們是用 KiB 為單位展示的,但是按下 E(擴展內存縮放 extend memory scaling)可以輪換不同的單位:KiB、MiB、GiB、TiB、PiB、EiB(kilobytes、megabytes、gigabytes、terabytes、petabytes 和 exabytes)

top 用戶手冊有更多選項和配置項信息。你可以運行 man top 來查看你系統上的文檔。還有很多 HTML 版的 man 手冊 ,但是請留意,這些手冊可能是針對不同 top 版本的。

兩個 top 的替代品

你不必總是用 top 查看系統狀態。你可以根據你的情況用其它工具來協助排查問題,尤其是當你想要更圖形化或更專業的界面的時候。

htop

htop 很像 top,但是它帶來了一些非常有用的東西:它可以以圖形界面展示 CPU 和內存使用情況。

Linux中使用top命令的技巧

這是我們在剛才運行 top 的同一環境中 htop 的樣子。顯示更簡潔,但功能卻很豐富。

任務統計、負載、uptime 和進程列表仍然在,但是它有了漂亮、彩色、動態的每核 CPU 使用情況,還有圖形化的內存使用情況。

以下是不同顏色的含義(你也可以通過按下 h 來獲得這些信息的幫助)。

CPU 任務優先級或類型:

  • 藍色:低優先級
  • 綠色:正常優先級
  • 紅色:內核任務
  • 藍色:虛擬任務
  • 條狀圖末尾的值是已用 CPU 的百分比

內存:

  • 綠色:已經使用的內存
  • 藍色:緩沖的內存
  • 黃色:緩存內存
  • 條狀圖末尾的值顯示已用內存和總內存

如果顏色對你沒用,你可以運行 htop -C 來禁用它們;那樣 htop 將使用不同的符號來展示 CPU 和內存類型。

它的底部有一組激活的快捷鍵提示,可以用來操作過濾結果或改變排序順序。試著按一些快捷鍵看看它們能做什么。不過嘗試 F9 時要小心,它會調出一個信號列表,這些信號會殺死(即停止)一個過程。我建議在生產環境之外探索這些選項。

htop 的作者 Hisham Muhammad(是的,htop 的名字就是源自 Hisham 的)在二月份的 FOSDEM 2018 做了一個 簡短的演講 。他闡述了 htop 不僅有簡潔的圖形界面,還有更現代的進程信息統計展示方式,這都是之前的工具(如 top)所不具備的。

你可以在 手冊頁面 或 htop 網站 閱讀更多關于 htop 的信息。(提示:網站背景是一個動態的 htop。)

docker stats

如果你在用Docker,你可以運行 docker stats 來為容器狀態生成一個有豐富上下文的界面。

這可能比 top 更有幫助,因為它不是按進程分類,而是按容器分類的。這點特別有用,當某個容器運行緩慢時,查看哪個容器耗資源最多比運行 top 再找到容器的進程要快。

借助于上面對top和htop術語的解釋,你應該會更容易理解docker stats 中的那些。然而,docker stats 文檔 對每一列都提供了詳盡的描述。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。如果你想了解更多相關內容請查看下面相關鏈接

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

富阳市| 泗阳县| 泽州县| 浦县| 东阿县| 泸西县| 灌阳县| 松溪县| 双辽市| 库尔勒市| 吉木萨尔县| 屯留县| 名山县| 双江| 泉州市| 樟树市| 临洮县| 宁波市| 光山县| 淮滨县| 上蔡县| 天台县| 湘潭县| 连州市| 新兴县| 漳州市| 开鲁县| 绥江县| 新化县| 饶河县| 连南| 长宁县| 江陵县| 昌乐县| 高青县| 扎兰屯市| 宜春市| 中西区| 新邵县| 千阳县| 浦城县|