什么是vmstat
- 概念:vmstat測量上下文切換的次數(shù),vmstat命令是最常見的Linux/Unix監(jiān)控工具荆萤,可以展現(xiàn)給定時間間隔的服務器的狀態(tài)值,包括服務器的CPU使用率舍咖,內(nèi)存使用矩父,虛擬內(nèi)存交換情況,IO讀寫情況。這個命令是我查看Linux/Unix最喜愛的命令排霉,一個是Linux/Unix都支持窍株,二是相比top,我可以看到整個機器的CPU,內(nèi)存,IO的使用情況攻柠,而不是單單看到各個進程的CPU使用率和內(nèi)存使用率(使用場景不一樣)球订。
- 常用參數(shù):一般vmstat工具的使用是通過兩個數(shù)字參數(shù)來完成的,第一個參數(shù)是采樣的時間間隔數(shù)瑰钮,單位是秒冒滩,第二個參數(shù)是采樣的次數(shù)
實例:
root@ubuntu:~# vmstat 2 1
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
r b swpd free buff cache si so bi bo in cs us sy id wa
1 0 0 3498472 315836 3819540 0 0 0 1 2 0 0 0 100 0
2表示每個兩秒采集一次服務器狀態(tài),1表示只采集一次浪谴。
- 實際上开睡,在應用過程中,我們會在一段時間內(nèi)一直監(jiān)控苟耻,不想監(jiān)控直接結束vmstat就行了,例如:
root@ubuntu:~# vmstat 2
procs -----------memory---------- ---swap-- -----io---- -system-- ----cpu----
r b swpd free buff cache si so bi bo in cs us sy id wa
1 0 0 3499840 315836 3819660 0 0 0 1 2 0 0 0 100 0
0 0 0 3499584 315836 3819660 0 0 0 0 88 158 0 0 100 0
0 0 0 3499708 315836 3819660 0 0 0 2 86 162 0 0 100 0
0 0 0 3499708 315836 3819660 0 0 0 10 81 151 0 0 100 0
1 0 0 3499732 315836 3819660 0 0 0 2 83 154 0 0 100 0
這表示vmstat每2秒采集數(shù)據(jù)篇恒,一直采集,直到我結束程序凶杖,這里采集了5次數(shù)據(jù)我就結束了程序胁艰。
命令介紹完畢,現(xiàn)在開始實戰(zhàn)講解每個參數(shù)的意思。
- r 表示運行隊列(就是說多少個進程真的分配到CPU)腾么,我測試的服務器目前CPU比較空閑醋虏,沒什么程序在跑,當這個值超過了CPU數(shù)目哮翘,就會出現(xiàn)CPU瓶頸了颈嚼。這個也和top的負載有關系,一般負載超過了3就比較高饭寺,超過了5就高阻课,超過了10就不正常了,服務器的狀態(tài)很危險艰匙。top的負載類似每秒的運行隊列限煞。如果運行隊列過大,表示你的CPU很繁忙员凝,一般會造成CPU使用率很高署驻。
- b 表示阻塞的進程,這個不多說,進程阻塞健霹,大家懂的旺上。
- swpd 虛擬內(nèi)存已使用的大小,如果大于0糖埋,表示你的機器物理內(nèi)存不足了宣吱,如果不是程序內(nèi)存泄露的原因,那么你該升級內(nèi)存了或者把耗內(nèi)存的任務遷移到其他機器瞳别。
- free 空閑的物理內(nèi)存的大小征候,我的機器內(nèi)存總共8G,剩余3415M祟敛。
- buff Linux/Unix系統(tǒng)是用來存儲疤坝,目錄里面有什么內(nèi)容,權限等的緩存馆铁,我本機大概占用300多M
- cache cache直接用來記憶我們打開的文件,給文件做緩沖跑揉,我本機大概占用300多M(這里是Linux/Unix的聰明之處,把空閑的物理內(nèi)存的一部分拿來做文件和目錄的緩存叼架,是為了提高 程序執(zhí)行的性能畔裕,當程序使用內(nèi)存時,buffer/cached會很快地被使用乖订。)
- si 每秒從磁盤讀入虛擬內(nèi)存的大小扮饶,如果這個值大于0,表示物理內(nèi)存不夠用或者內(nèi)存泄露了乍构,要查找耗內(nèi)存進程解決掉甜无。我的機器內(nèi)存充裕扛点,一切正常。
- so 每秒虛擬內(nèi)存寫入磁盤的大小岂丘,如果這個值大于0陵究,同上。
- bi 塊設備每秒接收的塊數(shù)量奥帘,這里的塊設備是指系統(tǒng)上所有的磁盤和其他塊設備铜邮,默認塊大小是1024byte,我本機上沒什么IO操作寨蹋,所以一直是0松蒜,但是我曾在處理拷貝大量數(shù)據(jù)(2-3T)的機器上看過可以達到140000/s,磁盤寫入速度差不多140M每秒
- bo 塊設備每秒發(fā)送的塊數(shù)量已旧,例如我們讀取文件秸苗,bo就要大于0。bi和bo一般都要接近0运褪,不然就是IO過于頻繁惊楼,需要調(diào)整。
- in 每秒CPU的中斷次數(shù)秸讹,包括時間中斷
- cs 每秒上下文切換次數(shù)檀咙,例如我們調(diào)用系統(tǒng)函數(shù),就要進行上下文切換嗦枢,線程的切換攀芯,也要進程上下文切換,這個值要越小越好文虏,太大了,要考慮調(diào)低線程或者進程的數(shù)目,例如在apache和nginx這種web服務器中殖演,我們一般做性能測試時會進行幾千并發(fā)甚至幾萬并發(fā)的測試氧秘,選擇web服務器的進程可以由進程或者線程的峰值一直下調(diào),壓測趴久,直到cs到一個比較小的值丸相,這個進程和線程數(shù)就是比較合適的值了。系統(tǒng)調(diào)用也是彼棍,每次調(diào)用系統(tǒng)函數(shù)灭忠,我們的代碼就會進入內(nèi)核空間,導致上下文切換座硕,這個是很耗資源弛作,也要盡量避免頻繁調(diào)用系統(tǒng)函數(shù)。上下文切換次數(shù)過多表示你的CPU大部分浪費在上下文切換华匾,導致CPU干正經(jīng)事的時間少了映琳,CPU沒有充分利用,是不可取的。
- us 用戶CPU時間萨西,我曾經(jīng)在一個做加密解密很頻繁的服務器上有鹿,可以看到us接近100,r運行隊列達到80(機器在做壓力測試,性能表現(xiàn)不佳)谎脯。
- sy 系統(tǒng)CPU時間葱跋,如果太高,表示系統(tǒng)調(diào)用時間長源梭,例如是IO操作頻繁年局。
id 空閑 CPU時間,一般來說咸产,id + us + sy = 100,一般我認為id是空閑CPU使用率矢否,us是用戶CPU使用率,sy是系統(tǒng)CPU使用率脑溢。 - wt 等待IO CPU時間僵朗。
awk 是什么,怎么用屑彻?
- awk是用來提取列的主要工具
- {print $1}就是將某一行(一條記錄)中以空格為分割符的第一個字段打印出來
給你舉個例子
echo "aa bb cc" | awk -F '{print $1}' 結果就是aa验庙,意思是把字符串按空格分割,取第一個社牲,自己做個測試就明白了粪薛!
image
如果你覺得文章還不錯,你的轉發(fā)搏恤、分享违寿、贊賞、點贊熟空、留言就是對我最大的鼓勵藤巢。 感謝您的閱讀,我堅持原創(chuàng)息罗,十分歡迎并感謝您的關注掂咒。
原創(chuàng)不易,歡迎轉發(fā)迈喉,關注公眾號“碼農(nóng)進階之路”绍刮,獲取更多面試題,源碼解讀資料挨摸!
在這里插入圖片描述