国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

聊聊 Top 命令中的 CPU 使用率

商務辦公
當系統中沒有可運行的進程時,將會執行 idle 進程。也就是說,當系統執行 idle 進程時,表示系統正處于空閑狀態。

[[402755]]

本文轉載自微信公眾號「Linux內核那些事」,作者songsong001。轉載本文請聯系Linux內核那些事公眾號。

平常我們使用 top 命令來查看系統的性能情況,在 top 命令中可以看到很多不同類型的 CPU 使用率,如下圖紅框中標出部分:

下面,我們來介紹一下這些 CPU 使用率的意義:

  • us:user time,表示 CPU 執行用戶進程的時間,包括 nice 時間。通常都是希望用戶空間CPU越高越好。
  • sy:system time,表示 CPU 在內核運行的時間,包括 IRQ 和 softirq。系統 CPU 占用越高,表明系統某部分存在瓶頸。通常這個值越低越好。
  • ni:nice time,具有優先級的用戶進程執行時占用的 CPU 利用率百分比。
  • id:idle time,表示系統處于空閑期,等待進程運行。
  • wa:waiting time,表示 CPU 在等待 IO 操作完成所花費的時間。系統不應該花費大量的時間來等待 IO 操作,否則就說明 IO 存在瓶頸。
  • hi:hard IRQ time,表示系統處理硬中斷所花費的時間。
  • si:soft IRQ time,表示系統處理軟中斷所花費的時間。
  • st:steal time,被強制等待(involuntary wait)虛擬 CPU 的時間,此時 Hypervisor 在為另一個虛擬處理器服務。

當然,單靠上面的解釋來理解它們的意義還是比較困難的。所以,本文主要從源碼的角度來分析它們到底代表什么。

時鐘中斷

首先,我們要知道統計 CPU 使用情況在什么地方執行的。在分析之前,我們先來了解下 時鐘中斷:

時鐘中斷:是一種硬中斷,由時間硬件(系統定時器,一種可編程硬件)產生。當 CPU 接收到時鐘中斷信號后,會在處理完當前指令后調用 時鐘中斷處理程序 來完成更新系統時間、執行周期性任務等。

可以發現,統計 CPU 使用情況是在 時鐘中斷處理程序 中完成的。

每個 CPU 的使用情況通過 cpu_usage_stat 結構來記錄,我們來看看其定義:

  1. struct cpu_usage_stat { 
  2.     cputime64_t user
  3.     cputime64_t nice; 
  4.     cputime64_t system; 
  5.     cputime64_t softirq; 
  6.     cputime64_t irq; 
  7.     cputime64_t idle; 
  8.     cputime64_t iowait; 
  9.     cputime64_t steal; 
  10.     cputime64_t guest; 
  11. }; 

從 cpu_usage_stat 結構的定義可以看出,其每個字段與 top 命令的 CPU 使用率類型一一對應。在內核初始化時,會為每個 CPU 創建一個 cpu_usage_stat 結構,用于統計 CPU 的使用情況。

OK,現在我們來分析下內核是怎么統計 CPU 的使用情況的。

每次執行 時鐘中斷處理程序 都會調用 account_process_tick 函數進行 CPU 使用情況統計,我們來分析一下 account_process_tick 函數的實現:

  1. void account_process_tick(struct task_struct *p, int user_tick) 
  2.     cputime_t one_jiffy_scaled = cputime_to_scaled(cputime_one_jiffy); 
  3.     struct rq *rq = this_rq(); 
  4.  
  5.     // 說明:user_tick 變量標識當前是否處于執行用戶應用程序 
  6.  
  7.     if (user_tick) { 
  8.         // 1. 如果 CPU 在執行用戶程序, 那么調用 account_user_time 進行統計 
  9.         account_user_time(p, cputime_one_jiffy, one_jiffy_scaled); 
  10.     } else if ((p != rq->idle) || (irq_count() != HARDIRQ_OFFSET)) { 
  11.         // 2. 如果 CPU 在執行內核代碼, 那么調用 account_system_time 進行統計 
  12.         account_system_time(p, HARDIRQ_OFFSET, cputime_one_jiffy, 
  13.                             one_jiffy_scaled); 
  14.     } else { 
  15.         // 3. 否則說明 CPU 在執行 idle 進程(也就是處于空閑狀態), 那么調用 account_idle_time 進行統計 
  16.         account_idle_time(cputime_one_jiffy); 
  17.     } 

account_process_tick 函數主要分 3 種情況進行統計,如下:

如果 CPU 在執行用戶程序,那么調用 account_user_time 進行統計。

如果 CPU 在執行內核代碼,那么調用 account_system_time 進行統計。

否則說明 CPU 在執行 idle 進程(也就是處于空閑狀態),那么調用 account_idle_time 進行統計。

CPU 使用情況統計

下面我們分別對這 3 種統計進行分析。

1. 統計用戶程序執行時間

統計用戶程序的執行時間是通過 account_user_time 函數來完成的,我們來看看其實現:

  1. void account_user_time(struct task_struct *p, cputime_t cputime, 
  2.                        cputime_t cputime_scaled) 
  3.     // 獲取 CPU 的統計結構(每個CPU一個 cpu_usage_stat 結構) 
  4.     struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;  
  5.     cputime64_t tmp; 
  6.     ... 
  7.  
  8.     // 分 2 種情況統計 CPU 的使用情況 
  9.     // 1. 如果進程的 nice 值大于0, 那么將會統計到 nice 字段中 
  10.     // 2. 如果進程的 nice 值小于等于0, 那么將會統計到 user 字段中 
  11.     if (TASK_NICE(p) > 0) 
  12.         cpustat->nice = cputime64_add(cpustat->nice, tmp); 
  13.     else 
  14.         cpustat->user = cputime64_add(cpustat->user, tmp); 
  15.     ... 

account_user_time 函數主要分兩種情況統計:

  • 如果進程的 nice 值大于0,那么將會增加到 CPU 統計結構的 nice 字段中。
  • 如果進程的 nice 值小于等于0,那么增加到 CPU 統計結構的 user 字段中。

這里說明一下進程 nice 值的作用,nice 值越大,說明進程的優先級越低。所以,nice 統計值主要用來統計低優先級進程的占使用 CPU 的情況。也說明了,user 和 nice 統計值都屬于執行用戶程序的 CPU 時間。

2. 統計內核代碼執行時間

如果在發生時鐘中斷前,CPU 處于內核態,也就是說在執行內核代碼。那么將會調用 account_system_time 函數進行統計,account_system_time 函數實現如下:

  1. void account_system_time(struct task_struct *p, int hardirq_offset, 
  2.                          cputime_t cputime, cputime_t cputime_scaled) 
  3.     // 獲取 CPU 的統計結構(每個CPU一個 cpu_usage_stat 結構) 
  4.     struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat; 
  5.     cputime64_t tmp; 
  6.     ... 
  7.  
  8.     // 主要分 3 種情況進行統計 
  9.     // 1. 如果當前處于硬中斷執行上下文, 那么統計到 irq 字段中 
  10.     // 2. 如果當前處于軟中斷執行上下文, 那么統計到 softirq 字段中 
  11.     // 3. 否則統計到 system 字段中 
  12.     if (hardirq_count() - hardirq_offset) 
  13.         cpustat->irq = cputime64_add(cpustat->irq, tmp); 
  14.     else if (softirq_count()) 
  15.         cpustat->softirq = cputime64_add(cpustat->softirq, tmp); 
  16.     else 
  17.         cpustat->system = cputime64_add(cpustat->system, tmp); 
  18.     ... 

account_system_time 函數主要分 3 種情況進行統計:

如果當前處于硬中斷執行上下文,那么增加到 CPU 統計結構的 irq 字段中。

如果當前處于軟中斷執行上下文,那么增加到 CPU 統計結構的 softirq 字段中。

否則增加到 CPU 統計結構的 system 字段中。

從上面代碼可以看出,irq 和 softirq 統計值也算是內核代碼執行時間。

3. idle 進程執行時間統計

當系統中沒有可運行的進程時,將會執行 idle 進程。也就是說,當系統執行 idle 進程時,表示系統正處于空閑狀態。

idle 進程執行時間統計由 account_idle_time 函數完成,其實現如下:

  1. void account_idle_time(cputime_t cputime) 
  2.     struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat; 
  3.     cputime64_t cputime64 = cputime_to_cputime64(cputime); 
  4.     struct rq *rq = this_rq(); 
  5.  
  6.     // 分 2 種情況統計 CPU 的使用情況 
  7.     // 1. 如果系統有進程正在等待 I/O 操作完成, 那么將統計到 iowait 字段中 
  8.     // 2. 否則將統計到 idle 字段中 
  9.     if (atomic_read(&rq->nr_iowait) > 0) 
  10.         cpustat->iowait = cputime64_add(cpustat->iowait, cputime64); 
  11.     else 
  12.         cpustat->idle = cputime64_add(cpustat->idle, cputime64); 

account_idle_time 函數也分兩種情況進行統計:

  • 如果系統中有正在等待 I/O 操作完成的進程,那么增加到 CPU 統計結構的 iowait 字段中。
  • 否則增加到 CPU 統計結構的 idle 字段中。

從上面的分析可以看出,iowait 統計值也屬于空閑時間的一種。

top 命令的 CPU 使用率

通過源碼分析,我們知道 top 命令中 CPU 使用率各種類型的意思,現在我們來介紹一下 top 命令是怎么計算各種類型的 CPU 使用率。

要獲取各個 CPU 的使用情況信息,可以通過讀取 /proc/stat 文件獲取,如下:

  1. [vagrant@localhost ~]$ cat /proc/stat 
  2. cpu  245 10 1142 1097923 95 0 28 0 0 0 
  3. cpu0 245 10 1142 1097923 95 0 28 0 0 0 
  4. ... 

上面的結果顯示了 CPU 的使用情況信息,第一行代表所有 CPU 的總和,而第二行開始表示每個 CPU 核心的使用情況信息。因為我的電腦只有一個核,所以只有一條數據。

下面說說這些數據的意義,從第一個數值開始分別代表:user ,nice,system,idle,iowait, irq,softirq,steal。

所以,top 命令的 CPU 使用率計算公式如下:

  1. CPU總時間 = user + nice + system + idle + wait + irq + softirq + steal 
  2. %us = user / CPU總時間 
  3. %ni = nice / CPU總時間 
  4. %sy = system / CPU總時間 
  5. %id = idel / CPU總時間 
  6. %wa = wait / CPU總時間 
  7. %hi = irq / CPU總時間 
  8. %si = softirq / CPU總時間 
  9. %st = steal / CPU總時間 

嗯,看起來還是挺簡單的。

總結

本文主要分析了 top 命令中的 CPU 使用率的意義和實現原理,希望通過本文,能夠幫助大家對 top 命令有更深的認識。

 

責任編輯:武曉燕 來源: Linux內核那些事
相關推薦

2021-08-10 11:45:57

topCPULinux

2024-04-11 13:27:19

Linuxtop命令

2019-01-15 15:04:54

CPU電腦使用率

2009-11-16 17:03:20

Oracle優化CPU

2021-11-11 16:46:02

CPU使用率 .NET

2013-04-12 09:39:01

Top監控系統

2020-07-08 07:00:00

LinuxCPU應用程序

2022-07-23 21:31:24

KubernetesLinux開源

2014-12-01 13:44:03

cgroupscpulimitlinux

2010-04-27 10:32:54

Oracle優化CPU

2022-04-11 07:50:58

top 命令Java 系統JVM 進程

2019-09-24 14:52:35

CPU負載Linux

2010-04-12 11:21:35

Oracle優化CPU

2023-03-06 08:41:32

CPU使用率排查

2009-12-15 15:12:05

Linux限制進程cp

2010-01-18 10:13:08

VB.NET獲取CPU

2017-05-03 11:10:14

Linux進程監控cpustat

2017-03-23 19:27:55

LinuxCPUCPU利用率

2022-09-15 08:01:32

CPU使用率異步

2013-09-18 11:00:14

JavaCPU
點贊
收藏

51CTO技術棧公眾號

欧美色精品在线视频| 欧美中文字幕在线观看| 在线观看免费av网| 国产女人水真多18毛片18精品视频| 久久av二区| 国产韩国精品一区二区三区| 91精品国产亚洲| 日韩精品中文字幕吗一区二区| 精品日韩在线观看| 亚洲视频tv| 在线亚洲一区二区| 在线视频尤物| 亚洲一区在线免费观看| 日本xxxxwwww| 国产精品高潮久久久久无| 日本一区二区黄色| 成人免费毛片a| 青青视频免费在线观看| 蜜桃视频一区二区三区在线观看 | 米奇777在线欧美播放| 91久久精品国产91性色| 日韩成人a**站| 国产日韩欧美在线播放| 爽成人777777婷婷| 18成人免费观看网站下载| 日本一区二区精品| 午夜亚洲视频| 亚洲一区二区三区精品在线观看 | 国产精品美女免费| 亚洲成人最新网站| 国产尤物91| 欧美a级理论片| 强开小嫩苞一区二区三区网站 | 香蕉av一区| 欧美视频裸体精品| 九一国产在线| 8x8x8国产精品| 日本孕妇大胆孕交无码| 亚洲国产黄色片| 午夜伦理福利在线| 亚洲欧美精品一区二区| 亚洲天堂资源| 欧美日本亚洲视频| 国产精品一区二区av日韩在线| 国产精品成人va在线观看| 日韩av专区| 欧美日韩在线高清| 精品一区二区三区的国产在线播放| 国产精品波多野结衣| 99精品1区2区| 日本韩国福利视频| 欧美日韩激情一区| 欧美亚洲韩国| 欧美在线免费视频| 国语自产精品视频在线看8查询8| 青青影院一区二区三区四区| 国产成人自拍高清视频在线免费播放| 国产在线观看福利| 亚洲国产精品久久久男人的天堂| 黄色av网址在线免费观看| 精品欧美乱码久久久久久| 色8久久久久| 成人av在线亚洲| 麻豆精品在线看| 成人淫片免费视频95视频| 91国产丝袜在线播放| 周于希免费高清在线观看| 5566日本婷婷色中文字幕97| 在线成人欧美| 国产无限制自拍| 亚洲6080在线| 免费电影日韩网站| 国产又爽又黄的激情精品视频| 性欧美xxxx大乳国产app| 欧美日韩一区二区在线免费观看| 激情懂色av一区av二区av| 美女av在线免费看| 国产精品久久久久久久久久99| 美女一区二区三区| 自由色视频.| 国产一区二区三区三区在线观看| 国产精品一区二区99| 超薄肉色丝袜足j调教99| 亚洲愉拍自拍另类高清精品| 国产91足控脚交在线观看| 欧美一级视频在线观看| 麻豆精品在线观看| 日韩有码电影| 欧美精品电影在线| 欧美激情护士| 亚洲一区二区高清视频| 久久精品在线观看| 国产九区一区在线| 欧美激情在线一区二区| 日本一级理论片在线大全| 午夜免费日韩视频| 久久免费黄色| 黑料吃瓜在线观看| 欧美a在线视频| 中文字幕免费精品一区| 久久99精品久久久久久青青日本| 91碰在线视频| 国产在线1区| 国产精品扒开腿做爽爽爽视频 | 黄www在线观看| 日韩欧美一二三四区| 精品综合久久88少妇激情| 一区二区三区av| 在线日韩av片| 国产一区不卡| www.天天射.com| 国产午夜精品视频免费不卡69堂| 一区二区高清| 日本福利片高清在线观看| 中文字幕亚洲欧美在线| 欧美三级电影精品| 国产一区二区伦理片| 国产呻吟对白刺激无套视频在线| 中文字幕精品视频| 日韩久久99| 91在线最新| 成人图片小说| 美脚丝袜一区二区三区在线观看| 国产一区二区网址| 精品中文字幕av| 日韩女优av电影在线观看| 91成人国产| 在线观看国产高清视频| 日本中文字幕久久看| 欧美国产国产综合| 亚洲国产欧美国产第一区| 99热在线这里只有精品| 中文字幕国产亚洲| 懂色av噜噜一区二区三区av| 国产中文在线播放| 穿情趣内衣被c到高潮视频| 亚洲第一区中文字幕| 免费在线欧美视频| 新版的欧美在线视频| 在线看成人av电影| 亚洲九九九在线观看| 国产精品996| 精品久久亚洲| 国产日本视频| 91影视免费在线观看| 欧美在线free| 日本不卡视频一二三区| 色婷婷av在线| 桥本有菜av在线| 亚洲性夜色噜噜噜7777| 成人久久视频在线观看| 国产一区二区久久久久| 美女在线视频一区二区| 国产精品丝袜久久久久久不卡| 黑人狂躁日本妞一区二区三区| 狠狠88综合久久久久综合网| 黄色免费在线网站| 日韩精品手机在线观看| 精品精品国产国产自在线| 亚洲欧洲日韩av| 91精品秘密在线观看| av免费在线观看网站| 99久久99久久精品| 91爱视频在线| 欧美视频一区二| 五月伊人六月| 精品久久久久久乱码天堂| 亚洲国产精品高清久久久| 91蝌蚪国产九色| 欧美一区二区三区高清视频| 六十路在线观看| 国产乱人伦丫前精品视频| 网红女主播少妇精品视频| 久久精品五月| av影片在线看| av磁力番号网| 欧美激情综合亚洲一二区| 亚洲国产成人av网| 99在线|亚洲一区二区| 欧美精品高清| juliaann成人作品在线看| 高清亚洲高清| 四虎8848精品成人免费网站| 国产日韩亚洲欧美| 不用播放器成人网| 综合136福利视频在线| 亚洲欧美综合另类中字| 欧美色男人天堂| 欧美成人性战久久| 久久在线免费视频| 日本高清不卡的在线| www.日韩.com| 91精品国产自产在线观看永久∴ | 亚洲精品视频二区| 亚洲日本在线看| 日韩高清不卡一区二区三区| 白嫩白嫩国产精品| 欧美午夜大胆人体| 自由色视频.| 男女日批视频在线观看|