Linux之性能監(jiān)測命令解讀
一、Mpstat命令
實(shí)時(shí)系統(tǒng)監(jiān)控工具,此命令會(huì)展現(xiàn)cpu、的一些統(tǒng)計(jì)信息,這些信息存放在/proc/stat文件中,在多cpu系統(tǒng)里,其不但能查看所有cpu的平均狀況信息,而且能夠查看特定cpu信息。
Mpstat語法
mpstat ? ?[-P {|ALL}] ? ? [internal ? ?[count]]?-P:指定要監(jiān)控那個(gè)CPU,范圍是[0~n-1],ALL表示監(jiān)控所有CPUinternal:相鄰兩次采樣的間隔時(shí)間count:采樣次數(shù)
直接使用mpstat命令

各列的含義:
Cpu:處理器idUsr:在internet時(shí)間段里,cpu一共花了多少比例的時(shí)間運(yùn)行在用戶態(tài)空間或者說是用戶進(jìn)程。Nice:用戶空間進(jìn)程的cpu‘的調(diào)度優(yōu)先級(jí)Sys:核心時(shí)間,CPU花了多少比例的時(shí)間在內(nèi)核空間運(yùn)行。分配內(nèi)存、IO操作、創(chuàng)建子進(jìn)程……都是內(nèi)核操作。這也表明,當(dāng)IO操作頻繁時(shí),System參數(shù)會(huì)很高。Iowait:硬盤io等待時(shí)間,在計(jì)算機(jī)中,讀寫磁盤的操作遠(yuǎn)比cpu運(yùn)行的速度要慢,cpu負(fù)載處理數(shù)據(jù),而數(shù)據(jù)一般在磁盤上需要讀到內(nèi)存中才能處理Irq:硬中斷時(shí)間,硬中斷是由外部事件引起的具有隨機(jī)性和突發(fā)性Soft:軟中斷時(shí)間,軟中斷是執(zhí)行中斷指令產(chǎn)生的Steal:顯示虛擬機(jī)管理器在服務(wù)另一個(gè)虛擬處理器時(shí)虛擬cpu處在非資源等待下花費(fèi)時(shí)間的百分比即虛擬機(jī)強(qiáng)制cpu等待的時(shí)間的百分比Gnice:CPU運(yùn)行niced guest虛擬機(jī)所花費(fèi)的時(shí)間百分比Guest:顯示運(yùn)行虛擬處理器時(shí)花費(fèi)時(shí)間的百分比Idle:cpu出去等待磁盤io操作外的因?yàn)槿魏卧蚨臻e的時(shí)間閑置時(shí)間即cpu空閑時(shí)間百分比
指定參數(shù)查看
mpstat -P ALL 3 3 :查看所有cpu,每三秒查看一次,查看3次。

單獨(dú)查看 一個(gè)cpu
mpstat -P 0 1 2 單獨(dú)指向一個(gè)cpu,需要注意的cpu序號(hào)是從0開始的

stress壓力測試
stress 是Unix類系統(tǒng)下的工作量和壓力測試工具。它可對(duì)用戶指定的CPU數(shù)量的I/O,內(nèi)存和硬盤進(jìn)行負(fù)載并報(bào)告它檢測到任何錯(cuò)誤。
工具安裝:
如果采用YUM安裝方式,則需要首先安裝epel的擴(kuò)展源,然后安裝stress即可,相關(guān)命令如下: yum install -y epel-release yum install -y stress
常用參數(shù):
| -c | cpu | 產(chǎn)生n個(gè)進(jìn)程,每個(gè)進(jìn)程都反復(fù)不停的計(jì)算隨機(jī)數(shù)的平方根 |
| -i | io | 產(chǎn)生n個(gè)進(jìn)程,每個(gè)進(jìn)程反復(fù)調(diào)用 將內(nèi)存上的內(nèi)容寫到硬盤上 |
| -m | vm | 產(chǎn)生n個(gè)進(jìn)程,每個(gè)進(jìn)程不斷分配和釋放內(nèi)存 |
| -t | timout | 在n秒后結(jié)束進(jìn)程 |
| -d | hdd | 產(chǎn)生n個(gè)不斷執(zhí)行 write 和unlink函數(shù)的進(jìn)程(創(chuàng)建文件、寫入內(nèi)容、刪除文件 |
壓力測試:


二、iostat命令
iostat主要用于輸出磁盤io和cpu的統(tǒng)計(jì)信息
iostat命令語法
iostat【選項(xiàng)】【時(shí)間間隔】【次數(shù)】
-c:顯示CPU使用情況-d:顯示磁盤使用情況-N:顯示磁盤陣列(LVM)信息-n:顯示NFS使用情況-k:以KB為單位顯示-m:以M為單位顯示-t:報(bào)告每秒向終端讀取和寫入的字符數(shù)和CPU的信息-V:顯示版本信息-x:顯示詳細(xì)信息-p:[磁盤]顯示磁盤和分區(qū)的情況

cpu屬性說明
user:CPU處在用戶模式下的時(shí)間百分比。nice:CPU處在帶NICE值的用戶模式下的時(shí)間百分比。system:CPU處在系統(tǒng)模式下的時(shí)間百分比。iowait:CPU等待輸入輸出完成時(shí)間的百分比。steal:管理程序維護(hù)另一個(gè)虛擬處理器時(shí),虛擬CPU的無意識(shí)等待時(shí)間百分比。idle:CPU空閑時(shí)間百分比。
磁盤屬性說明
device:磁盤名稱tps:每秒鐘發(fā)送到的I/O請(qǐng)求數(shù).Blk_read/s:每秒讀取的block數(shù).Blk_wrtn/s:每秒寫入的block數(shù).Blk_read:讀入的block總數(shù).Blk_wrtn:寫入的block總數(shù).
-x 詳細(xì)顯示說明

rrqm/s:每秒進(jìn)行merge的讀操作數(shù)目。即rmerge/swrqm/s:每秒進(jìn)行merge的寫操作數(shù)目。即wmerge/sr/s:每秒完成的讀I/O設(shè)備次數(shù)。即rio/sw/s:每秒完成的寫I/O設(shè)備次數(shù)。即wio/srkB/s:每秒讀K字節(jié)數(shù)。是rsect/s的一半,因?yàn)槊可葏^(qū)大小為512字節(jié)。wkB/s:每秒寫K字節(jié)數(shù)。是wsect/s的一半。avgrq-sz:平均每次設(shè)備I/O操作的數(shù)據(jù)大小(扇區(qū))。avgqu-sz:平均I/O隊(duì)列長度。r_await:每個(gè)讀操作平均所需的時(shí)間不僅包括硬盤設(shè)備讀操作的時(shí)間,還包括了在kernel隊(duì)列中等待的時(shí)間。w_await:每個(gè)寫操作平均所需的時(shí)間不僅包括硬盤設(shè)備寫操作的時(shí)間,還包括了在kernel隊(duì)列中等待的時(shí)間。await:平均每次設(shè)備I/O操作的等待時(shí)間(毫秒)。svctm:平均每次設(shè)備I/O操作的服務(wù)時(shí)間(毫秒)。%util:一秒中有百分之多少的時(shí)間用于I/O操作,即被io消耗的cpu百分比
只顯示磁盤設(shè)備 -d


三、iotop
iotop命令是一個(gè)用來監(jiān)視磁盤io使用狀況的top類工具。iotop具有與top相似的UI,其中包括PID、用戶、O、進(jìn)程等相關(guān)信息。
Linux下的IO統(tǒng)計(jì)工具如iostat,nmon等大多數(shù)是只能統(tǒng)計(jì)到per設(shè)備的讀寫情況,如果你想知道每個(gè)進(jìn)程是如何使用IO的就比較麻煩,使用iotop命令可以很方便的查看。
如果命令未安裝可以從yum倉庫進(jìn)行安裝
命令使用方法
Iotop(選項(xiàng))
-o:只顯示有io操作的進(jìn)程b:批量顯示,無交互,主要用作記錄到文件。-n NUM:顯示NUM次,主要用于非交互式模式。-d SEC:間隔SEC秒顯示一次。-p PID:監(jiān)控的進(jìn)程pid。-u USER:監(jiān)控的進(jìn)程用戶。
iotop常用快捷鍵:
- 1.左右箭頭:改變排序方式,默認(rèn)是按lO排序。
- 2.r:改變排序順序。
- 3.o:只顯示有IO輸出的進(jìn)程。
- 4.p:進(jìn)程/線程的顯示方式的切換。
- 5.a:顯示累積使用量。
- 6.q:退出。
命令效果:

四、pidstat
pidstat是sysstat工具的一個(gè)命令,用于監(jiān)控全部或指定進(jìn)程的cpu、內(nèi)存一、線程、設(shè)備IO等系統(tǒng)資源的占用情況。
pidstat首次運(yùn)行時(shí)顯示自系統(tǒng)啟動(dòng)開始的各項(xiàng)統(tǒng)計(jì)信息,之后運(yùn)行pidstat將顯示自上次運(yùn)行該命令以后的統(tǒng)計(jì)信息。
用戶可以通過指定統(tǒng)計(jì)的次數(shù)和時(shí)間來獲得所需的統(tǒng)計(jì)信息。
Pidstat使用方法
Pidstat 【選項(xiàng)】 【時(shí)間間隔】【次數(shù)】
常用參數(shù):
-u:默認(rèn)的參數(shù),顯示各個(gè)進(jìn)程的cpu使用統(tǒng)計(jì)-r:顯示各個(gè)進(jìn)程的內(nèi)存使用統(tǒng)計(jì)-d:顯示各個(gè)進(jìn)程的IO使用情況-p:指定進(jìn)程號(hào)-w:顯示每個(gè)進(jìn)程的上下文切換情況-t:顯示選擇任務(wù)的線程的統(tǒng)計(jì)信息外的額外信息
-T { TASK | CHILD | ALL }
這個(gè)選項(xiàng)指定了pidstat監(jiān)控的。TASK表示報(bào)告獨(dú)立的task,CHILD關(guān)鍵字表示報(bào)告進(jìn)程下所有線程統(tǒng)計(jì)信息。ALL表示報(bào)告獨(dú)立的task和task下面的所有線程。
注意:task和子線程的全局的統(tǒng)計(jì)信息和pidstat選項(xiàng)無關(guān)。這些統(tǒng)計(jì)信息不會(huì)對(duì)應(yīng)到當(dāng)前的統(tǒng)計(jì)間隔,這些統(tǒng)計(jì)信息只有在子線程kill或者完成的時(shí)候才會(huì)被收集。
-V:版本號(hào)-h:在一行上顯示了所有活動(dòng),這樣其他程序可以容易解析。-I:在SMP環(huán)境,表示任務(wù)的CPU使用率/內(nèi)核數(shù)量-l:顯示命令名和所有參數(shù)
示例一、查看所有進(jìn)程的 CPU 使用情況( -u -p ALL)

詳細(xì)說明
PID:進(jìn)程ID%usr:進(jìn)程在用戶空間占用cpu的百分比%system:進(jìn)程在內(nèi)核空間占用cpu的百分比%guest:進(jìn)程在虛擬機(jī)占用cpu的百分比%CPU:進(jìn)程占用cpu的百分比CPU:處理進(jìn)程的cpu編號(hào)Command:當(dāng)前進(jìn)程對(duì)應(yīng)的命令
示例二: 內(nèi)存使用情況統(tǒng)計(jì)(-r)

使用-r選項(xiàng),pidstat將顯示各活動(dòng)進(jìn)程的內(nèi)存使用統(tǒng)計(jì):
PID:進(jìn)程標(biāo)識(shí)符Minflt/s:任務(wù)每秒發(fā)生的次要錯(cuò)誤,不需要從磁盤中加載頁Majflt/s:任務(wù)每秒發(fā)生的主要錯(cuò)誤,需要從磁盤中加載頁VSZ:虛擬地址大小,虛擬內(nèi)存的使用KBRSS:常駐集合大小,非交換區(qū)五里內(nèi)存使用KBCommand:task命令名
示例三:顯示各個(gè)進(jìn)程的IO使用情況(-d)

報(bào)告IO統(tǒng)計(jì)顯示以下信息:
PID:進(jìn)程idkB_rd/s:每秒從磁盤讀取的KBkB_wr/s:每秒寫入磁盤KBkB_ccwr/s:任務(wù)取消的寫入磁盤的KB。當(dāng)任務(wù)截?cái)嗯K的pagecache的時(shí)候會(huì)發(fā)生。COMMAND:task的命令名
示例四:顯示每個(gè)進(jìn)程的上下文切換情況(-w)

PID:進(jìn)程idCswch/s:每秒主動(dòng)任務(wù)上下文切換數(shù)量Nvcswch/s:每秒被動(dòng)任務(wù)上下文切換數(shù)量Command:命令名
示例五:顯示選擇任務(wù)的線程的統(tǒng)計(jì)信息外的額外信息 (-t)

TGID:主線程的表示TID:線程id%usr:進(jìn)程在用戶空間占用cpu的百分比%system:進(jìn)程在內(nèi)核空間占用cpu的百分比%guest:進(jìn)程在虛擬機(jī)占用cpu的百分比%CPU:進(jìn)程占用cpu的百分比CPU:處理進(jìn)程的cpu編號(hào)Command:當(dāng)前進(jìn)程對(duì)應(yīng)的命令
五、lsof
lsof命令用于查看你進(jìn)程開打的文件,打開文件的進(jìn)程,進(jìn)程打開的端口(TCP、UDP)。找回/恢復(fù)刪除的文件。
是十分方便的系統(tǒng)監(jiān)視工具,因?yàn)閘sof命令需要訪問核心內(nèi)存和各種文件,所以需要root用戶執(zhí)行。
在linux環(huán)境下,任何事物都以文件的形式存在,通過文件不僅僅可以訪問常規(guī)數(shù)據(jù),還可以訪問網(wǎng)絡(luò)連接和硬件。
所以如傳輸控制協(xié)議 (TCP) 和用戶數(shù)據(jù)報(bào)協(xié)議 (UDP) 套接字等,系統(tǒng)在后臺(tái)都為該應(yīng)用程序分配了一個(gè)文件描述符,無論這個(gè)文件的本質(zhì)如何,該文件描述符為應(yīng)用程序與基礎(chǔ)操作系統(tǒng)之間的交互提供了通用接口。
因?yàn)閼?yīng)用程序打開文件的描述符列表提供了大量關(guān)于這個(gè)應(yīng)用程序本身的信息,因此通過lsof工具能夠查看這個(gè)列表對(duì)系統(tǒng)監(jiān)測以及排錯(cuò)將是很有幫助的。
語法
lsof(選項(xiàng))
| 選項(xiàng) | 描述 |
|---|---|
| -a | 列出打開文件存在的進(jìn)程; |
| -c<進(jìn)程名> | 列出指定進(jìn)程所打開的文件; |
| -g | 列出GID號(hào)進(jìn)程詳情; |
| -d<文件號(hào)> | 列出占用該文件號(hào)的進(jìn)程; |
| +d<目錄> | 列出目錄下被打開的文件; |
| +D<目錄> | 遞歸列出目錄下被打開的文件; |
| -n<目錄> | 列出使用NFS的文件; |
| -i<條件> | 列出符合條件的進(jìn)程。(4、6、協(xié)議、:端口、 @ip ) |
| -p<進(jìn)程號(hào)> | 列出指定進(jìn)程號(hào)所打開的文件; |
| -u | 列出UID號(hào)進(jìn)程詳情; |
| -h | 顯示幫助信息 |
| -v | 顯示版本信息 |
[root@localhost~]# lsof command PID USER FD type DEVICE SIZE NODE NAME
lsof輸出各列信息的意義如下
COMMAND:進(jìn)程的名稱PID:進(jìn)程標(biāo)識(shí)符PPID:父進(jìn)程標(biāo)識(shí)符(需要指定-R參數(shù))USER:進(jìn)程所有者PGID:進(jìn)程所屬組FD:文件描述符,應(yīng)用程序通過文件描述符識(shí)別該文件。DEVICE:指定磁盤的名稱SIZE:文件的大小NODE:索引節(jié)點(diǎn)(文件在磁盤上的標(biāo)識(shí))NAME:打開文件的確切名稱
FD文件描述符列表
cwd:表示current work dirctory,即:應(yīng)用程序的當(dāng)前工作目錄,這是該應(yīng)用程序啟動(dòng)的目錄,除非它本身對(duì)這個(gè)目錄進(jìn)行更改txt:該類型的文件是程序代碼,如應(yīng)用程序二進(jìn)制文件本身或共享庫,如上列表中顯示的 /sbin/init 程序lnn:library references (AIX)(庫引用);er:FD information error (see NAME column)(fd信息錯(cuò)誤);jld:jail directory (FreeBSD)(監(jiān)控目錄);ltx:shared library text (code and data)(共享庫文本);mxx:hex memory-mapped type number xx(十六進(jìn)制內(nèi)存映射類型號(hào)xx);m86:DOS Merge mapped file(DOS合并映射文件);mem:memory-mapped file(內(nèi)存映射文件);mmap:memory-mapped device(內(nèi)存映射設(shè)備);pd:parent directory(父目錄);rtd:root directory(跟目錄);tr:kernel trace file (OpenBSD)(內(nèi)核跟蹤文件);v86 VP/ix mapped file(VP/IX映射文件);- 0:表示標(biāo)準(zhǔn)輸出
- 1:表示標(biāo)準(zhǔn)輸入
- 2:表示標(biāo)準(zhǔn)錯(cuò)誤
文件類型:
DIR:表示目錄。CHR:表示字符類型。BLK:塊設(shè)備類型。UNIX: UNIX 域套接字。FIFO:先進(jìn)先出 (FIFO) 隊(duì)列。IPv4:網(wǎng)際協(xié)議 (IP) 套接字。DEVICE:指定磁盤的名稱SIZE:文件的大小NODE:索引節(jié)點(diǎn)(文件在磁盤上的標(biāo)識(shí))NAME:打開文件的確切名稱
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
虛擬機(jī)ubuntu16.04無法連網(wǎng)的解決方法
這篇文章主要為大家詳細(xì)介紹了虛擬機(jī)ubuntu16.04無法連網(wǎng)的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-03-03
騰訊云服務(wù)器部署前后分離項(xiàng)目之前端部署
本文主要介紹了騰訊云服務(wù)器部署前后分離項(xiàng)目之前端部署,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06
詳解如何在 Linux 啟動(dòng)時(shí)自動(dòng)執(zhí)行命令或腳本
這篇文章主要介紹了詳解如何在 Linux 啟動(dòng)時(shí)自動(dòng)執(zhí)行命令或腳本,主要有兩種方式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03
3分鐘學(xué)會(huì)如何上手supervisor看門狗
這篇文章主要介紹了3分鐘學(xué)會(huì)如何上手supervisor看門狗,文章中操作步驟講解的很清楚,有需要的同學(xué)可以研究下2021-02-02
Ubuntu16.04上安裝CUDA9.0 詳細(xì)教程
這篇文章主要介紹了Ubuntu16.04上安裝CUDA9.0 詳細(xì)教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08

