最近看到一大牛的分析報告,才知道筆者以前認(rèn)識這4個命令是多么膚淺,其實要讀懂內(nèi)存的信息,是要一些功力的。
創(chuàng)新互聯(lián)是一家專業(yè)從事網(wǎng)站設(shè)計制作、做網(wǎng)站、網(wǎng)頁設(shè)計的品牌網(wǎng)絡(luò)公司。如今是成都地區(qū)具影響力的網(wǎng)站設(shè)計公司,作為專業(yè)的成都網(wǎng)站建設(shè)公司,創(chuàng)新互聯(lián)依托強(qiáng)大的技術(shù)實力、以及多年的網(wǎng)站運營經(jīng)驗,為您提供專業(yè)的成都網(wǎng)站建設(shè)、營銷型網(wǎng)站建設(shè)及網(wǎng)站設(shè)計開發(fā)服務(wù)!
1、top
VIRT虛擬內(nèi)存總量,VIRT=SWAP+RES
SWAP使用的虛擬內(nèi)存中被換出的大小
RES進(jìn)程使用的、未被換出的物理內(nèi)存大小
SHR共享內(nèi)存大小,單位kb
S進(jìn)程狀態(tài)
%MEM進(jìn)程使用的物理內(nèi)存百分比
%CPU CPU時間占用百分比
Mem: 191272k total物理內(nèi)存總量
173656k used使用的物理內(nèi)存總量
17616k free空閑內(nèi)存總量
22052k buffers用作內(nèi)核緩存的內(nèi)存量
Swap: 192772k total交換區(qū)總量
0k used使用的交換區(qū)總量
192772k free空閑交換區(qū)總量
123988k cached緩沖的交換區(qū)總量。內(nèi)存中的內(nèi)容被換出到交換區(qū),而后又被換入到內(nèi)存,但使用過的交換區(qū)尚未被覆蓋,該數(shù)值即為這些內(nèi)容已存在于內(nèi)存中的交換區(qū)的大小。相應(yīng)的內(nèi)存再次被換出時可不必再對交換區(qū)寫入。
2、free
主要關(guān)注值
Mem物理內(nèi)存統(tǒng)計
total物理內(nèi)存總量。
used總計分配給緩存(包含buffers 與cache )使用的數(shù)量
free未被分配的內(nèi)存
shared 共享內(nèi)存
buffers 系統(tǒng)分配但未被使用的buffers 數(shù)量,兩種主要Cache方式之一,針對磁盤塊的讀寫(塊設(shè)備緩存)
cached 系統(tǒng)分配但未被使用的cache 數(shù)量,兩種主要Cache方式之一,針對文件inode的讀寫(文件系統(tǒng)緩存)
-/+buffers/cached物理內(nèi)存的緩存統(tǒng)計
used(第一行Mem值)used - buffers -cached ,系統(tǒng)實際使用的內(nèi)存總量
free(第一行Mem值)buffers + cached ,系統(tǒng)當(dāng)前實際可用內(nèi)存
Mem從操作系統(tǒng)層面分析,buffers cached是已分配的(已使用)內(nèi)存
-/+ buffers/cached從應(yīng)用程序?qū)用娣治?,buffers cached是隨時都可以拿來用的,而且是優(yōu)先使用的
Swap交換分區(qū)的使用情況
3、vmstat
r表示運行隊列, 值超過了CPU數(shù)目,就會出現(xiàn)CPU瓶頸
b表示阻塞的進(jìn)程,觀察iowait值,通常是由于IO等待引起
swpd虛擬內(nèi)存已使用的大小,如果大于0,表示物理內(nèi)存不足,注意程序內(nèi)存泄露
free空閑的物理內(nèi)存的大小
buff
cache直接記憶打開的文件,給文件做緩沖,Linux/Unix把空閑的物理內(nèi)存的一部分拿來做文件和目錄的緩存,是為了提高程序執(zhí)行的性能,當(dāng)程序使用內(nèi)存時,buffer/cached會很快地被使用
如果cache值較大,相應(yīng)的bi會減少
si每秒從磁盤讀入虛擬內(nèi)存的大小(俗稱換進(jìn)),值大于0,表示物理內(nèi)存不夠或者內(nèi)存泄露
so每秒虛擬內(nèi)存寫入磁盤的大?。ㄋ壮鰮Q出),值大于0,表示物理內(nèi)存不夠或者內(nèi)存泄露
如果swpd值不為0,但si so值長期為0,這種情況不會影響系統(tǒng)性能,但如果值長期大于0,CPU資源和IO資源都會受影響,系統(tǒng)性能下降
bi 從塊設(shè)備讀入的數(shù)據(jù)總量(讀磁盤)(KB/s)
bo 寫入到塊設(shè)備的數(shù)據(jù)總理(寫磁盤)(KB/s)
in每秒CPU的中斷次數(shù),包括時間中斷
cs每秒上下文切換次數(shù),例如我們調(diào)用系統(tǒng)函數(shù),就要進(jìn)行上下文切換,線程的切換,也要進(jìn)程上下文切換,這個值要越小越好,太大了,要考慮調(diào)低線程或者進(jìn)程的數(shù)目,例如在apache和nginx這種web服務(wù)器中,我們一般做性能測試時會進(jìn)行幾千并發(fā)甚至幾萬并發(fā)的測試,選擇web服務(wù)器的進(jìn)程可以由進(jìn)程或者線程的峰值一直下調(diào),壓測,直到cs到一個比較小的值,這個進(jìn)程和線程數(shù)就是比較合適的值了。系統(tǒng)調(diào)用也是,每次調(diào)用系統(tǒng)函數(shù),我們的代碼就會進(jìn)入內(nèi)核空間,導(dǎo)致上下文切換,這個是很耗資源,也要盡量避免頻繁調(diào)用系統(tǒng)函數(shù)。上下文切換次數(shù)過多表示你的CPU大部分浪費在上下文切換,導(dǎo)致CPU干正經(jīng)事的時間少了,CPU沒有充分利用,是不可取的
us用戶CPU時間
sy系統(tǒng)CPU時間,如果太高,表示系統(tǒng)調(diào)用時間長,例如是IO操作頻繁
id空閑 CPU時間
wt等待IOCPU時間
4、iostat
iostat option
-c 顯示CPU
-d 顯示Device,通常指磁盤
-p 顯示磁盤分區(qū)信息,不能與-x同時使用
-k 單位為KB
-m 單位為MB
-n 顯示NFS信息
-t 顯示時間,與AIX的時間顯示有差別
-x 顯示更詳細(xì)信息
常用命令1:iostat
常用命令2:iostat -x
rrqm/s每秒進(jìn)行 merge的讀操作數(shù)目,即 delta(rmerge)/s
wrqm/s每秒進(jìn)行 merge的寫操作數(shù)目,即 delta(wmerge)/s
r/s每秒完成的讀 I/O設(shè)備次數(shù),即 delta(rio)/s
w/s每秒完成的寫 I/O設(shè)備次數(shù)。即delta(wio)/s
兩值相加=iops,磁盤性能三大分析因素之一,尤其是小文件的系統(tǒng)
rsec/s每秒讀扇區(qū)數(shù),即delta(rsect)/s
wsec/s:每秒寫扇區(qū)數(shù),即delta(wsect)/s
rkB/s每秒讀K字節(jié)數(shù),是 rsect/s的一半,因為每扇區(qū)大小為512字節(jié)
wkB/s每秒寫K字節(jié)數(shù),是 wsect/s的一半
avgrq-sz平均每次設(shè)備I/O操作的數(shù)據(jù)大小(扇區(qū)),delta(rsect+wsect)/delta(rio+wio)
avgqu-sz平均I/O隊列長度,即delta(aveq)/s/1000 (因為aveq的單位為毫秒)。
await 平均每次設(shè)備I/O操作的等待時間 (毫秒),即 delta(ruse+wuse)/delta(rio+wio)
svctm 平均每次設(shè)備I/O操作的服務(wù)時間 (毫秒),即 delta(use)/delta(rio+wio)
服務(wù)時間,俗稱響應(yīng)時間,數(shù)據(jù)庫尤其注得此值
%util:一秒中有百分之多少的時間用于 I/O操作,或者說一秒中有多少時間 I/O隊列是非空的
僅讀懂上述每個參數(shù)的意義是不夠的,我們應(yīng)該分析參數(shù)之間的關(guān)聯(lián)關(guān)系,即一個參數(shù)的變化會引起另一個參數(shù)的上下波動
從而找出系統(tǒng)真正的瓶勁,好對癥下藥。