日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

概述

今天主要帶大家深入理解下CPU負載和cpu使用率方面的內容,看下這中間是怎么計算的。


CPU負載和 CPU使用率

這兩個從一定程度上都可以反映一臺機器的繁忙程度.

cpu使用率反映的是當前cpu的繁忙程度,忽高忽低的原因在于占用cpu處理時間的進程可能處于io等待狀態但卻還未釋放進入wait。

平均負載(load average)是指某段時間內占用cpu時間的進程和等待cpu時間的進程數,這里等待cpu時間的進程是指等待被喚醒的進程,不包括處于wait狀態進程。

以上分析可以看出,一臺機器很有可能處于低cpu使用率高負載的情況,因此看機器的繁忙程度應該結合兩者,在cpu還空閑的情況下,如何提高io響應是減少負載的關鍵,很多人認為負載到幾十了機器就非常繁忙了,其實如果這個時候cpu使用率比較低,則負載高可能不能很好說明問題,一旦cpu處理的進程處理完后,那些等待的進程也能立刻得到響應,這種情況下應該優化io讀寫速度。真到cpu使用率一直90%以上,即使平均負載只有個位數(比如某一個進程一直在運算),那機器其實也已經繁忙了~


CPU負載的一個類比

判斷系統負荷是否過重,必須理解load average的真正含義。

深入探究Linux系統CPU負載和CPU使用率

 

首先,假設最簡單的情況,你的電腦只有一個CPU,所有的運算都必須由這個CPU來完成。

那么不妨把這個CPU想象成一座大橋,橋上只有一根車道,所有車輛都必須從這根車道上通過。(很顯然,這座橋只能單向通行。)

系統負荷為0,意味著大橋上一輛車也沒有。

系統負荷為0.5,意味著大橋一半的路段有車。

系統負荷為1.0,意味著大橋的所有路段都有車,也就是說大橋已經"滿"了。但是必須注意的是,直到此時大橋還是能順暢通行的。

系統負荷為1.7,意味著車輛太多了,大橋已經被占滿了(100%),后面等著上橋的車輛為橋面車輛的70%。以此類推,系統負荷2.0,意味著等待上橋的車輛與橋面的車輛一樣多;系統負荷3.0,意味著等待上橋的車輛是橋面車輛的2倍。總之,當系統負荷大于1,后面的車輛就必須等待了;系統負荷越大,過橋就必須等得越久。

CPU的系統負荷,基本上等同于上面的類比。大橋的通行能力,就是CPU的最大工作量;橋梁上的車輛,就是一個個等待CPU處理的進程(process)。

如果CPU每分鐘最多處理100個進程,那么系統負荷0.2,意味著CPU在這1分鐘里只處理20個進程;系統負荷1.0,意味著CPU在這1分鐘里正好處理100個進程;系統負荷1.7,意味著除了CPU正在處理的100個進程以外,還有70個進程正排隊等著CPU處理。

為了電腦順暢運行,系統負荷最好不要超過1.0,這樣就沒有進程需要等待了,所有進程都能第一時間得到處理。很顯然,1.0是一個關鍵值,超過這個值,系統就不在最佳狀態了,你要動手干預了。


CPU負載-多處理器

上面假設電腦只有1個CPU。如果電腦裝了2個CPU,會發生什么情況呢?

2個CPU,意味著電腦的處理能力翻了一倍,能夠同時處理的進程數量也翻了一倍。

還是用大橋來類比,兩個CPU就意味著大橋有兩根車道了,通車能力翻倍了。

所以,2個CPU表明系統負荷可以達到2.0,此時每個CPU都達到100%的工作量。推廣開來,n個CPU的電腦,可接受的系統負荷最大為n.0。


CPU負載-多核處理器

芯片廠商往往在一個CPU內部,包含多個CPU核心,這被稱為多核CPU。

在系統負荷方面,多核CPU與多CPU效果類似,所以考慮系統負荷的時候,必須考慮這臺電腦有幾個CPU、每個CPU有幾個核心。然后,把系統負荷除以總的核心數,只要每個核心的負荷不超過1.0,就表明電腦正常運行。

怎么知道電腦有多少個CPU核心呢?

  • "cat /proc/cpuinfo"命令,可以查看CPU信息。
  • "grep -c 'model name' /proc/cpuinfo"命令,直接返回CPU的總核心數。
深入探究Linux系統CPU負載和CPU使用率

 


系統負荷的經驗法則

系統負荷的經驗法則是:

當系統負荷持續大于0.7,你必須開始調查了,問題出在哪里,防止情況惡化。

當系統負荷持續大于1.0,你必須動手尋找解決辦法,把這個值降下來。

當系統負荷達到5.0,就表明系統有很嚴重的問題,長時間沒有響應,或者接近死機了,正常不應該讓系統達到這個值。

對于我的機器,有8個core,那么,load多少合適呢?

#grep 'model name' /proc/cpuinfo | wc -l
#echo "0.7*24" |bc
深入探究Linux系統CPU負載和CPU使用率

 


最佳觀察時長

我們一般在用top觀察cpu負載時,其中的"load average"一共返回三個平均值----1分鐘系統負荷、5分鐘系統負荷,15分鐘系統負荷,那么應該參考哪個值呢?

深入探究Linux系統CPU負載和CPU使用率

 

如果只有1分鐘的系統負荷大于1.0,其他兩個時間段都小于1.0,這表明只是暫時現象,問題不大。

如果15分鐘內,平均系統負荷大于1.0(調整CPU核心數之后),表明問題持續存在,不是暫時現象。所以,你應該主要觀察"15分鐘系統負荷",將它作為電腦正常運行的指標。

分享到:
標簽:負載 Linux CPU
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定