您好,登錄后才能下訂單哦!
很早就想寫一下,但最近太忙了,還要準(zhǔn)備下CET-4悲催的日子...哈哈...
先寫點(diǎn),慢慢寫吧...
一:
A:ps -l 查看屬于自己這次登錄的PID與相關(guān)信息列出來(只與自己的bash有關(guān))
F:代表這個(gè)進(jìn)程標(biāo)志(process flags),說明這個(gè)進(jìn)程的權(quán)限,常見號(hào)碼有:
1,若為4表示此進(jìn)程的權(quán)限為root;
2,若為1則表示此子進(jìn)程僅可進(jìn)行復(fù)制(fork)而無法執(zhí)行(exec);
S:代表這個(gè)進(jìn)程的狀態(tài)(STAT),主要的狀態(tài)有:
R(Running):該進(jìn)程正在運(yùn)行中;
S(Sleep):該進(jìn)程目前正在睡眠狀態(tài)(idle),但可以被喚醒(signal);
D:不可被喚醒的狀態(tài),通常這個(gè)進(jìn)程可能在等待I/O的情況(ex>打?。?;
T:停止?fàn)顟B(tài)(stop),可能是在工作控制(后臺(tái)暫停)或出錯(cuò)(traced)狀態(tài);
Z(Zombie):“僵尸”狀態(tài),該進(jìn)程已經(jīng)終止但卻無法被刪除至內(nèi)存外。
UID/PID/PPID:代表此進(jìn)程被該UID所擁有的/進(jìn)程的PID號(hào)碼/此進(jìn)程的父進(jìn)程PID號(hào)碼。
C:代表CPU使用率,單位為百分比。
PRI/IN:Priority/Nice的縮寫,代表此進(jìn)程被CPU所執(zhí)行的優(yōu)先級(jí),數(shù)值越小代表此進(jìn)程越快被CPU執(zhí)行。
ADDR/SZ/WCHAN:都與內(nèi)存有關(guān),ADDR是kernel function,指出該進(jìn)程在內(nèi)存的哪個(gè)部分,如果是個(gè)running的進(jìn)程,一般會(huì)顯示“—”。SZ代表此進(jìn)程用掉多少內(nèi)存。WCHAN表示目前進(jìn)程是否在運(yùn)行中,同樣,若為“—”表示正在運(yùn)行中。
TTY:登錄者的終端位置,若為遠(yuǎn)程登錄使用動(dòng)態(tài)終端接口(pts/n)。
TIME:使用CPU的時(shí)間,注意,是此進(jìn)程實(shí)際花費(fèi)CPU運(yùn)行的時(shí)間,而不是系統(tǒng)時(shí)間。
CMD:就是command的縮寫,造成此程序的觸發(fā)進(jìn)程的命令為何。
B: ps aux 查看系統(tǒng)所有進(jìn)程數(shù)據(jù)(靜態(tài))
USER:該進(jìn)程屬于哪個(gè)用戶賬號(hào)的;
PID:該進(jìn)程的進(jìn)程標(biāo)識(shí)符;
%CPU:該進(jìn)程使用掉的CPU資源百分比;
%MEM:該進(jìn)程所占用的物理內(nèi)存百分比;
VSZ:該進(jìn)程所占用的虛擬內(nèi)存量(KB);
RSS:該進(jìn)程所占用的固定的內(nèi)存量(KB);
TTY:該進(jìn)程在哪個(gè)終端機(jī)上面運(yùn)行,若與終端機(jī)無關(guān)則顯示?另外,tty1~tty6是本機(jī)上面的登錄者程序,若為pts/0等的,則表示為由網(wǎng)絡(luò)連接進(jìn)主機(jī)的進(jìn)程;
STAT:該進(jìn)程目前的狀態(tài),狀態(tài)顯示與ps -l的S標(biāo)識(shí)相同(R/S/T/Z);
TIME:該進(jìn)程實(shí)際使用CPU的時(shí)間;
COMMAND:該進(jìn)程的實(shí)際命令。
二:top (動(dòng)態(tài))
統(tǒng)計(jì)信息區(qū)前五行是系統(tǒng)整體的統(tǒng)計(jì)信息。
第一行是任務(wù)隊(duì)列信息,同 uptime 命令的執(zhí)行結(jié)果。其內(nèi)容如下:
02:44:02 當(dāng)前時(shí)間
up 21 days ,2:12 開機(jī)到目前為止所經(jīng)過的時(shí)間
3 users 當(dāng)前登錄用戶數(shù)
0.56, 0.23, 0.32 系統(tǒng)負(fù)載,即任務(wù)隊(duì)列的平均長(zhǎng)度。三個(gè)數(shù)值分別為1分鐘、5分鐘、15分鐘前到現(xiàn)在的平均值。
第二行為進(jìn)程信息,內(nèi)容如下:
Tasks: 113 total 進(jìn)程總數(shù)
1 running 正在運(yùn)行的進(jìn)程數(shù)
112sleeping 睡眠的進(jìn)程數(shù)
0 stopped 停止的進(jìn)程數(shù)
0 zombie 僵尸進(jìn)程數(shù)
第三行為CPU信息,當(dāng)有多個(gè)CPU時(shí),這些內(nèi)容可能會(huì)超過兩行。內(nèi)容如下:
Cpu(s): 0.0%us 用戶空間占用CPU百分比
0.0% sy 內(nèi)核空間占用CPU百分比
0.0% ni 用戶進(jìn)程空間內(nèi)改變過優(yōu)先級(jí)的進(jìn)程占用CPU百分比
0.0% id 空閑CPU百分比
0.0% wa 等待輸入輸出(IO)的CPU時(shí)間百分比
0.0% hi cpu處理硬件中斷的時(shí)間;
0.0% si cpu處理軟中斷的時(shí)間;
0.0% st 在虛擬環(huán)境下,處理其他作業(yè)系統(tǒng)占用的 cpu 時(shí)間
第四行為內(nèi)存信息,內(nèi)容如下:
Mem: 1034872k total 物理內(nèi)存總量
974264k used 使用的物理內(nèi)存總量
60608k free 空閑內(nèi)存總量
226140k buffers 用作內(nèi)核緩存的內(nèi)存量
第五行為SWAP信息
Swap: 1534072k total 交換區(qū)總量
0used 使用的虛擬內(nèi)存總量
1534072k free 空閑交換區(qū)總量
548268k cached 緩沖的交換區(qū)總量。
第六行往后是進(jìn)程列表,常見的這幾列的意義分別為:
PID(進(jìn)程號(hào)), USER(運(yùn)行用戶),PR(優(yōu)先級(jí)),NI(任務(wù)nice值),VIRT(虛擬內(nèi)存用量),RES(物理內(nèi)存用量), SHR(共享內(nèi)存用量),S(進(jìn)程狀態(tài)),%CPU(CPU占用比),%MEM(內(nèi)存占用比),TIME+(累計(jì)CPU占用時(shí)間)。
除了這些信息之外,top還提供了很多命令能幫我們更好的解讀這些信息,例如按”M”鍵可以按內(nèi)存用量進(jìn)行排序;
按”P”可以按CPU使用量進(jìn)行排序,這樣一來對(duì)于分析系統(tǒng)瓶頸很有幫助;此外,按“f”可以進(jìn)入交互頁(yè)面,選擇指定的列顯示;
”r”可以改變一個(gè)進(jìn)程的nice值;”k”可以向一個(gè)進(jìn)程發(fā)信號(hào);
”z”可以使用彩色顯示。進(jìn)程信息區(qū)統(tǒng)計(jì)信息區(qū)域的下方顯示了各個(gè)進(jìn)程的詳細(xì)信息。
首先來認(rèn)識(shí)一下各列的含義。
序號(hào) 列名 含義
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 啟動(dòng)進(jìn)程的終端名。不是從終端啟動(dòng)的進(jìn)程則顯示為 ?
h PR 優(yōu)先級(jí)
i NI nice值。負(fù)值表示高優(yōu)先級(jí),正值表示低優(yōu)先級(jí)
j P 最后使用的CPU,僅在多CPU環(huán)境下有意義
k %CPU 上次更新到現(xiàn)在的CPU時(shí)間占用百分比
l TIME 進(jìn)程使用的CPU時(shí)間總計(jì),單位秒
m TIME+ 進(jìn)程使用的CPU時(shí)間總計(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 頁(yè)面錯(cuò)誤次數(shù)
v nDRT 最后一次寫入到現(xiàn)在,被修改過的頁(yè)面數(shù)。
w S 進(jìn)程狀態(tài)。
x COMMAND 命令名/命令行
y WCHAN 若該進(jìn)程在睡眠,則顯示睡眠中的系統(tǒng)函數(shù)名
z Flags 任務(wù)標(biāo)志,參考 sched.h
D=不可中斷的睡眠狀態(tài)
R=運(yùn)行
S=睡眠
T=跟蹤/停止
Z=僵尸進(jìn)程
默認(rèn)情況下僅顯示比較重要的 PID、USER、PR、NI、VIRT、RES、SHR、S、% CPU、%MEM、TIME+、COMMAND 列??梢酝ㄟ^下面的快捷鍵來更改顯示內(nèi)容。
更改顯示內(nèi)容通過 f 鍵可以選擇顯示的內(nèi)容。按 f 鍵之后會(huì)顯示列的列表,按 a-z 即可顯示或隱藏對(duì)應(yīng)的列,最后按回車鍵確定。
三:last 列出目前與過去登入系統(tǒng)的用戶相關(guān)信息。
參 數(shù):
- R: 省略 hostname 的欄位
-n:指定輸出記錄的條數(shù)。
-f file:指定用文件file作為查詢用的log文件。
-t tty:只顯示指定的虛擬控制臺(tái)上登錄情況。
-h(huán) 節(jié)點(diǎn):只顯示指定的節(jié)點(diǎn)上的登錄情況。
-i IP:只顯示指定的IP上登錄的情況。
-1:用IP來顯示遠(yuǎn)端地址。
-y:顯示記錄的年、月、日。
-ID:知道查詢的用戶名。
-x:顯示系統(tǒng)關(guān)閉、用戶登錄和退出的歷史。
補(bǔ)充說明:?jiǎn)为?dú)執(zhí)行l(wèi)ast指令,它會(huì)讀取/var/log/wtmp,并把該給文件的內(nèi)容記錄的登入系統(tǒng)的用戶名單全部顯示出來。
last用了顯示用戶登錄情況,以下是直接顯示固定行數(shù)的記錄
四:free
free -m 大小以M來顯示
說明:
第1行 :
total 內(nèi)存總數(shù): 1034872
used 已經(jīng)使用的內(nèi)存數(shù): 973820
free 空閑的內(nèi)存數(shù): 161502
shared 當(dāng)前已經(jīng)廢棄不用,總是0
buffers 內(nèi)存數(shù): 226260
cached 內(nèi)存數(shù): 548892
第2行:
-/+ buffers/cache的意思相當(dāng)于:
-buffers/cache 的內(nèi)存數(shù):198668 (等于第1行的 used - buffers - cached)
+buffers/cache 的內(nèi)存數(shù): 836204(等于第1行的 free + buffers + cached)
第3行:
total 交換分區(qū)總數(shù): 1534072
used 已經(jīng)使用的: 0
free 空閑的數(shù): 1534072
五:Linux iostat監(jiān)測(cè)IO狀態(tài)
1,iostat 無參數(shù)
以上顯示分為上下兩個(gè)部 分,上半部分顯示CPU的信息,下面的數(shù) 據(jù) 顯示存儲(chǔ)設(shè)備的相關(guān)數(shù)據(jù),它的數(shù)據(jù)意義如下:
tps:平均每秒鐘的傳送次數(shù),與數(shù)據(jù)傳輸“次數(shù)”相關(guān),非容 量
kB_read/s:?jiǎn)?dòng)到現(xiàn)在的平均讀取單位
kB_wrtn/s:?jiǎn)?dòng)到現(xiàn)在的平均寫入單位
kB_read:?jiǎn)?dòng)到現(xiàn)在總共 讀出來的文件 單位
kB_wrtn: 啟動(dòng)到現(xiàn)在總共寫入的文件單位
2,iostat -d -k 1 2
參數(shù) -d 表示,顯示設(shè)備(磁盤)使用狀態(tài);-k某些使用block為單位的列強(qiáng)制使用Kilobytes為單位;1 2表示,數(shù)據(jù)顯示每隔1秒刷新一次,共顯
示10次。
tps:該設(shè)備每秒的傳輸次數(shù)(Indicate the number of transfers per second that were issued to the device.)。“一次傳輸”意思是“一
次I/O請(qǐng)求”。多個(gè)邏輯請(qǐng)求可能會(huì)被合并為“一次I/O請(qǐng)求”。“一次傳輸”請(qǐng)求的大小是未知的。
kB_read/s:每秒從設(shè)備(drive expressed)讀取的數(shù)據(jù)量;kB_wrtn/s:每秒向設(shè)備(drive expressed)寫入的數(shù)據(jù)量;kB_read:讀取的總數(shù)據(jù)
量;kB_wrtn:寫入 的總數(shù)量數(shù)據(jù)量;這些單位都為Kilobytes。
上面的例子中,我們可以看到磁盤sda以及它的各個(gè)分區(qū)的統(tǒng)計(jì)數(shù)據(jù),當(dāng)時(shí)統(tǒng)計(jì)的磁盤總TPS是39.29,下面是各個(gè)分區(qū)的TPS。(因?yàn)槭撬查g 值,所
以總TPS并不嚴(yán)格等于各個(gè)分區(qū)TPS的總和)
3,-x 參數(shù)
使用-x參數(shù)我們可以獲得更多統(tǒng)計(jì)信息。
rrqm/s:每秒這個(gè)設(shè)備相關(guān)的讀取請(qǐng)求有多少被Merge了(當(dāng)系統(tǒng)調(diào)用需要讀取數(shù)據(jù)的 時(shí)候,VFS將請(qǐng)求發(fā)到各個(gè)FS,如果FS發(fā)現(xiàn)不同的讀取請(qǐng)求讀
取的是相同Block的數(shù)據(jù),F(xiàn)S會(huì)將這個(gè)請(qǐng)求合并Merge);wrqm/s:每秒這個(gè) 設(shè)備相關(guān)的寫入請(qǐng)求有多少被Merge了。
rsec/s:每秒讀取的扇區(qū)數(shù);wsec/: 每秒寫入的扇區(qū)數(shù)。r/s:The number of read requests that were issued to the device per second;
w/s:The number of write requests that were issued to the device per second;
await:每一個(gè)IO請(qǐng)求的處理的平均時(shí)間(單位是微秒)。這里可以理解為IO的響應(yīng)時(shí) 間,一般地系統(tǒng)IO響應(yīng)時(shí)間應(yīng)該低于5ms,如果大于10ms就比
較大了。
%util:在統(tǒng)計(jì)時(shí)間內(nèi)所有處理IO時(shí)間,除以總共統(tǒng)計(jì)時(shí)間。例如,如果統(tǒng)計(jì)間隔1秒,該 設(shè)備有0.8秒在處理IO,而0.2秒閑置,那么該設(shè)備的%
util = 0.8/1 = 80%,所以該參數(shù)暗示了設(shè)備的繁忙程度。一般地,如果該參數(shù)是100%表示設(shè)備已經(jīng)接近滿負(fù)荷運(yùn)行了(當(dāng)然如果是多磁盤,即
使%util是100%,因 為磁盤的并發(fā)能力,所以磁盤使用未必就到了瓶頸)。
4,-c 參數(shù)
iostat還可以用來獲取cpu部分狀態(tài)值:
5,常見用法
iostat -d -k 1 10 #查看TPS和吞吐量信息
iostat -d -x -k 1 10 #查看設(shè)備使用率(%util)、響應(yīng)時(shí)間(await)
iostat -c 1 10 #查看cpu狀態(tài)
第六:vmstat
rocs
r 列表示運(yùn)行和等待cpu時(shí)間片的進(jìn)程數(shù),如果長(zhǎng)期大于1,說明cpu不足,需要增加cpu。
b 列表示在等待資源的進(jìn)程數(shù),比如正在等待I/O、或者內(nèi)存交換等。
memory
swpd 切換到內(nèi)存交換區(qū)的內(nèi)存數(shù)量(k表示)。如果swpd的值不為0,或者比較大,比如超過了100m,只要si、so的值長(zhǎng)期為0,系統(tǒng)性能還是正常
free 當(dāng)前的空閑頁(yè)面列表中內(nèi)存數(shù)量(k表示)
buff 作為buffer cache的內(nèi)存數(shù)量,一般對(duì)塊設(shè)備的讀寫才需要緩沖。
cache: 作為page cache的內(nèi)存數(shù)量,一般作為文件系統(tǒng)的cache,如果cache較大,說明用到cache的文件較多,如果此時(shí)IO中bi比較小,說明文件系統(tǒng)效率比較好。
swap
si 由內(nèi)存進(jìn)入內(nèi)存交換區(qū)數(shù)量。
so由內(nèi)存交換區(qū)進(jìn)入內(nèi)存數(shù)量。
IO
bi 從塊設(shè)備讀入數(shù)據(jù)的總量(讀磁盤)(每秒kb)。
bo 塊設(shè)備寫入數(shù)據(jù)的總量(寫磁盤)(每秒kb)
這里我們?cè)O(shè)置的bi+bo參考值為1000,如果超過1000,而且wa值較大應(yīng)該考慮均衡磁盤負(fù)載,可以結(jié)合iostat輸出來分析。
system 顯示采集間隔內(nèi)發(fā)生的中斷數(shù)
in 列表示在某一時(shí)間間隔中觀測(cè)到的每秒設(shè)備中斷數(shù)。
cs列表示每秒產(chǎn)生的上下文切換次數(shù),如當(dāng) cs 比磁盤 I/O 和網(wǎng)絡(luò)信息包速率高得多,都應(yīng)進(jìn)行進(jìn)一步調(diào)查。
cpu 表示cpu的使用狀態(tài)
us 列顯示了用戶方式下所花費(fèi) CPU 時(shí)間的百分比。us的值比較高時(shí),說明用戶進(jìn)程消耗的cpu時(shí)間多,但是如果長(zhǎng)期大于50%,需要考慮優(yōu)化用戶的程序。
sy 列顯示了內(nèi)核進(jìn)程所花費(fèi)的cpu時(shí)間的百分比。這里us + sy的參考值為80%,如果us+sy 大于 80%說明可能存在CPU不足。
wa 列顯示了IO等待所占用的CPU時(shí)間的百分比。這里wa的參考值為30%,如果wa超過30%,說明IO等待嚴(yán)重,這可能是磁盤大量隨機(jī)訪問造成的,也可能磁盤或者磁盤訪問控制器的帶寬瓶頸造成的(主要
是塊操作)。
id 列顯示了cpu處在空閑狀態(tài)的時(shí)間百分比
st 在虛擬環(huán)境下,處理其他作業(yè)系統(tǒng)占用的 cpu 時(shí)間
第七:mpstat
%user 在internal時(shí)間段里,用戶態(tài)的CPU時(shí)間(%),不包含 nice值為負(fù) 進(jìn)程 (usr/total)*100
%nice 在internal時(shí)間段里,nice值為負(fù)進(jìn)程的CPU時(shí)間(%) (nice/total)*100
%sys 在internal時(shí)間段里,核心時(shí)間(%) (system/total)*100
%iowait 在internal時(shí)間段里,硬盤IO等待時(shí)間(%) (iowait/total)*100
%irq 在internal時(shí)間段里,硬中斷時(shí)間(%) (irq/total)*100
%soft 在internal時(shí)間段里,軟中斷時(shí)間(%) (softirq/total)*100
%steal在虛擬環(huán)境下,處理其他作業(yè)系統(tǒng)占用的 cpu 時(shí)間
%idle 在internal時(shí)間段里,CPU除去等待磁盤IO操作外的因?yàn)槿魏卧蚨臻e的時(shí)間閑置時(shí)間(%)(idle/total)*100
%intr/s 在internal時(shí)間段里,每秒CPU接收的中斷的次數(shù)intr/total)*100
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。