《菜鳥讀并發(fā)》vmstat可以測量線程上下文切換的次數(shù)

什么是vmstat

  1. 概念: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)存使用率(使用場景不一樣)球订。
  2. 常用參數(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)進階之路”绍刮,獲取更多面試題,源碼解讀資料挨摸!

在這里插入圖片描述

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末孩革,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子油坝,更是在濱河造成了極大的恐慌嫉戚,老刑警劉巖刨裆,帶你破解...
    沈念sama閱讀 222,252評論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異彬檀,居然都是意外死亡帆啃,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評論 3 399
  • 文/潘曉璐 我一進店門窍帝,熙熙樓的掌柜王于貴愁眉苦臉地迎上來努潘,“玉大人,你說我怎么就攤上這事坤学》枥ぃ” “怎么了?”我有些...
    開封第一講書人閱讀 168,814評論 0 361
  • 文/不壞的土叔 我叫張陵深浮,是天一觀的道長压怠。 經(jīng)常有香客問我,道長飞苇,這世上最難降的妖魔是什么菌瘫? 我笑而不...
    開封第一講書人閱讀 59,869評論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮布卡,結果婚禮上雨让,老公的妹妹穿的比我還像新娘。我一直安慰自己忿等,他們只是感情好栖忠,可當我...
    茶點故事閱讀 68,888評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著贸街,像睡著了一般庵寞。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上匾浪,一...
    開封第一講書人閱讀 52,475評論 1 312
  • 那天皇帮,我揣著相機與錄音,去河邊找鬼蛋辈。 笑死,一個胖子當著我的面吹牛将谊,可吹牛的內(nèi)容都是我干的冷溶。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼尊浓,長吁一口氣:“原來是場噩夢啊……” “哼逞频!你這毒婦竟也來了?” 一聲冷哼從身側響起栋齿,我...
    開封第一講書人閱讀 39,924評論 0 277
  • 序言:老撾萬榮一對情侶失蹤苗胀,失蹤者是張志新(化名)和其女友劉穎襟诸,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體基协,經(jīng)...
    沈念sama閱讀 46,469評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡歌亲,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,552評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了澜驮。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片陷揪。...
    茶點故事閱讀 40,680評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖杂穷,靈堂內(nèi)的尸體忽然破棺而出悍缠,到底是詐尸還是另有隱情,我是刑警寧澤耐量,帶...
    沈念sama閱讀 36,362評論 5 351
  • 正文 年R本政府宣布飞蚓,位于F島的核電站,受9級特大地震影響廊蜒,放射性物質發(fā)生泄漏趴拧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,037評論 3 335
  • 文/蒙蒙 一劲藐、第九天 我趴在偏房一處隱蔽的房頂上張望八堡。 院中可真熱鬧,春花似錦聘芜、人聲如沸兄渺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,519評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽挂谍。三九已至,卻和暖如春瞎饲,著一層夾襖步出監(jiān)牢的瞬間口叙,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,621評論 1 274
  • 我被黑心中介騙來泰國打工嗅战, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留妄田,地道東北人。 一個月前我還...
    沈念sama閱讀 49,099評論 3 378
  • 正文 我出身青樓驮捍,卻偏偏與公主長得像疟呐,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子东且,可洞房花燭夜當晚...
    茶點故事閱讀 45,691評論 2 361

推薦閱讀更多精彩內(nèi)容