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

聊聊 top 命令中的 CPU 使用率

系統(tǒng) Linux
本文主要分析了 top 命令中的 CPU 使用率的意義和實(shí)現(xiàn)原理,希望通過本文,能夠幫助大家對(duì) top 命令有更深的認(rèn)識(shí)。

 [[416565]]

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

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

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

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

[[416566]]

時(shí)鐘中斷

首先,我們要知道統(tǒng)計(jì) CPU 使用情況在什么地方執(zhí)行的。在分析之前,我們先來了解下 時(shí)鐘中斷:

時(shí)鐘中斷:是一種硬中斷,由時(shí)間硬件(系統(tǒng)定時(shí)器,一種可編程硬件)產(chǎn)生。當(dāng) CPU 接收到時(shí)鐘中斷信號(hào)后,會(huì)在處理完當(dāng)前指令后調(diào)用 時(shí)鐘中斷處理程序 來完成更新系統(tǒng)時(shí)間、執(zhí)行周期性任務(wù)等。

可以發(fā)現(xiàn),統(tǒng)計(jì) CPU 使用情況是在 時(shí)鐘中斷處理程序 中完成的。

每個(gè) CPU 的使用情況通過 cpu_usage_stat 結(jié)構(gòu)來記錄,我們來看看其定義: 

  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 結(jié)構(gòu)的定義可以看出,其每個(gè)字段與 top 命令的 CPU 使用率類型一一對(duì)應(yīng)。在內(nèi)核初始化時(shí),會(huì)為每個(gè) CPU 創(chuàng)建一個(gè) cpu_usage_stat 結(jié)構(gòu),用于統(tǒng)計(jì) CPU 的使用情況。

OK,現(xiàn)在我們來分析下內(nèi)核是怎么統(tǒng)計(jì) CPU 的使用情況的。

每次執(zhí)行 時(shí)鐘中斷處理程序 都會(huì)調(diào)用 account_process_tick 函數(shù)進(jìn)行 CPU 使用情況統(tǒng)計(jì),我們來分析一下 account_process_tick 函數(shù)的實(shí)現(xiàn): 

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

account_process_tick 函數(shù)主要分 3 種情況進(jìn)行統(tǒng)計(jì),如下:

  •  如果 CPU 在執(zhí)行用戶程序,那么調(diào)用 account_user_time 進(jìn)行統(tǒng)計(jì)。
  •  如果 CPU 在執(zhí)行內(nèi)核代碼,那么調(diào)用 account_system_time 進(jìn)行統(tǒng)計(jì)。
  •  否則說明 CPU 在執(zhí)行 idle 進(jìn)程(也就是處于空閑狀態(tài)),那么調(diào)用 account_idle_time 進(jìn)行統(tǒng)計(jì)。

CPU 使用情況統(tǒng)計(jì)

下面我們分別對(duì)這 3 種統(tǒng)計(jì)進(jìn)行分析。

1. 統(tǒng)計(jì)用戶程序執(zhí)行時(shí)間

統(tǒng)計(jì)用戶程序的執(zhí)行時(shí)間是通過 account_user_time 函數(shù)來完成的,我們來看看其實(shí)現(xiàn): 

  1. void account_user_time(struct task_struct *p, cputime_t cputime,  
  2.                        cputime_t cputime_scaled)  
  3.  
  4.     // 獲取 CPU 的統(tǒng)計(jì)結(jié)構(gòu)(每個(gè)CPU一個(gè) cpu_usage_stat 結(jié)構(gòu))  
  5.     struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;   
  6.     cputime64_t tmp;  
  7.     ...  
  8.     // 分 2 種情況統(tǒng)計(jì) CPU 的使用情況  
  9.     // 1. 如果進(jìn)程的 nice 值大于0, 那么將會(huì)統(tǒng)計(jì)到 nice 字段中  
  10.     // 2. 如果進(jìn)程的 nice 值小于等于0, 那么將會(huì)統(tǒng)計(jì)到 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 函數(shù)主要分兩種情況統(tǒng)計(jì):

  •  如果進(jìn)程的 nice 值大于0,那么將會(huì)增加到 CPU 統(tǒng)計(jì)結(jié)構(gòu)的 nice 字段中。
  •  如果進(jìn)程的 nice 值小于等于0,那么增加到 CPU 統(tǒng)計(jì)結(jié)構(gòu)的 user 字段中。

這里說明一下進(jìn)程 nice 值的作用,nice 值越大,說明進(jìn)程的優(yōu)先級(jí)越低。所以,nice 統(tǒng)計(jì)值主要用來統(tǒng)計(jì)低優(yōu)先級(jí)進(jìn)程的占使用 CPU 的情況。也說明了,user 和 nice 統(tǒng)計(jì)值都屬于執(zhí)行用戶程序的 CPU 時(shí)間。

2. 統(tǒng)計(jì)內(nèi)核代碼執(zhí)行時(shí)間

如果在發(fā)生時(shí)鐘中斷前,CPU 處于內(nèi)核態(tài),也就是說在執(zhí)行內(nèi)核代碼。那么將會(huì)調(diào)用 account_system_time 函數(shù)進(jìn)行統(tǒng)計(jì),account_system_time 函數(shù)實(shí)現(xiàn)如下: 

  1. void account_system_time(struct task_struct *p, int hardirq_offset,  
  2.                          cputime_t cputime, cputime_t cputime_scaled) 
  3.  
  4.     // 獲取 CPU 的統(tǒng)計(jì)結(jié)構(gòu)(每個(gè)CPU一個(gè) cpu_usage_stat 結(jié)構(gòu))  
  5.     struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;  
  6.     cputime64_t tmp;  
  7.     ...  
  8.     // 主要分 3 種情況進(jìn)行統(tǒng)計(jì)  
  9.     // 1. 如果當(dāng)前處于硬中斷執(zhí)行上下文, 那么統(tǒng)計(jì)到 irq 字段中  
  10.     // 2. 如果當(dāng)前處于軟中斷執(zhí)行上下文, 那么統(tǒng)計(jì)到 softirq 字段中  
  11.     // 3. 否則統(tǒng)計(jì)到 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 函數(shù)主要分 3 種情況進(jìn)行統(tǒng)計(jì):

  •  如果當(dāng)前處于硬中斷執(zhí)行上下文,那么增加到 CPU 統(tǒng)計(jì)結(jié)構(gòu)的 irq 字段中。
  •  如果當(dāng)前處于軟中斷執(zhí)行上下文,那么增加到 CPU 統(tǒng)計(jì)結(jié)構(gòu)的 softirq 字段中。
  •  否則增加到 CPU 統(tǒng)計(jì)結(jié)構(gòu)的 system 字段中。

從上面代碼可以看出,irq 和 softirq 統(tǒng)計(jì)值也算是內(nèi)核代碼執(zhí)行時(shí)間。

3. idle 進(jìn)程執(zhí)行時(shí)間統(tǒng)計(jì)

當(dāng)系統(tǒng)中沒有可運(yùn)行的進(jìn)程時(shí),將會(huì)執(zhí)行 idle 進(jìn)程。也就是說,當(dāng)系統(tǒng)執(zhí)行 idle 進(jìn)程時(shí),表示系統(tǒng)正處于空閑狀態(tài)。

idle 進(jìn)程執(zhí)行時(shí)間統(tǒng)計(jì)由 account_idle_time 函數(shù)完成,其實(shí)現(xiàn)如下: 

  1. void account_idle_time(cputime_t cputime)  
  2.  
  3.     struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;  
  4.     cputime64_t cputime64 = cputime_to_cputime64(cputime);  
  5.     struct rq *rq = this_rq();  
  6.     // 分 2 種情況統(tǒng)計(jì) CPU 的使用情況  
  7.     // 1. 如果系統(tǒng)有進(jìn)程正在等待 I/O 操作完成, 那么將統(tǒng)計(jì)到 iowait 字段中  
  8.     // 2. 否則將統(tǒng)計(jì)到 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 函數(shù)也分兩種情況進(jìn)行統(tǒng)計(jì):

  •  如果系統(tǒng)中有正在等待 I/O 操作完成的進(jìn)程,那么增加到 CPU 統(tǒng)計(jì)結(jié)構(gòu)的 iowait 字段中。
  •  否則增加到 CPU 統(tǒng)計(jì)結(jié)構(gòu)的 idle 字段中。

從上面的分析可以看出,iowait 統(tǒng)計(jì)值也屬于空閑時(shí)間的一種。

top 命令的 CPU 使用率

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

要獲取各個(gè) 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. ... 

上面的結(jié)果顯示了 CPU 的使用情況信息,第一行代表所有 CPU 的總和,而第二行開始表示每個(gè) CPU 核心的使用情況信息。因?yàn)槲业碾娔X只有一個(gè)核,所以只有一條數(shù)據(jù)。

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

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

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

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

總結(jié)

本文主要分析了 top 命令中的 CPU 使用率的意義和實(shí)現(xiàn)原理,希望通過本文,能夠幫助大家對(duì) top 命令有更深的認(rèn)識(shí)。 

 

責(zé)任編輯:龐桂玉 來源: 良許Linux
相關(guān)推薦

2021-05-31 15:53:57

CPU Top命令

2024-04-11 13:27:19

Linuxtop命令

2019-01-15 15:04:54

CPU電腦使用率

2009-11-16 17:03:20

Oracle優(yōu)化CPU

2021-11-11 16:46:02

CPU使用率 .NET

2013-04-12 09:39:01

Top監(jiān)控系統(tǒng)

2020-07-08 07:00:00

LinuxCPU應(yīng)用程序

2022-07-23 21:31:24

KubernetesLinux開源

2014-12-01 13:44:03

cgroupscpulimitlinux

2022-04-11 07:50:58

top 命令Java 系統(tǒng)JVM 進(jìn)程

2010-04-27 10:32:54

Oracle優(yōu)化CPU

2019-09-24 14:52:35

CPU負(fù)載Linux

2010-04-12 11:21:35

Oracle優(yōu)化CPU

2010-01-18 10:13:08

VB.NET獲取CPU

2009-12-15 15:12:05

Linux限制進(jìn)程cp

2023-03-06 08:41:32

CPU使用率排查

2017-05-03 11:10:14

Linux進(jìn)程監(jiān)控cpustat

2017-03-23 19:27:55

LinuxCPUCPU利用率

2022-09-15 08:01:32

CPU使用率異步

2012-07-02 16:38:22

Linux服務(wù)器閏秒
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

3d动漫成人在线| 337p日本| 久久精品免费一区二区三区| 亚洲精品一区av在线播放| 亚洲高清国产精品| 亚洲精选在线视频| 中文字幕天天干| 99综合电影在线视频| 欧美aaa在线观看| 爽好久久久欧美精品| 国产一区二区三区高清| 欧洲视频一区| 国产91对白在线播放| 国产一区二区视频在线看| 亚洲精品综合久久中文字幕| xxx.xxx欧美| 日韩一二三区视频| 波多野结衣在线一区| 亚洲一区二区偷拍精品| 91久久国产综合久久| www激情久久| 欧美一级黄色录像片| 久久九九99| 国内不卡一区二区三区| 欧美日韩亚洲一区| 国产有色视频色综合| 好看不卡的中文字幕| 动漫一区二区在线| 日韩精品一二三| 欧洲一区二区日韩在线视频观看免费| 日韩免费一级| 精品剧情在线观看| 天堂在线中文字幕| 国产精品视频免费| 久久美女福利视频| 国产精品欧美综合在线| 瑟瑟在线观看| 亚洲免费电影在线| 中文字幕在线观| 色成人在线视频| 成人在线播放| 亚洲欧洲视频在线| 二区三区精品| 美腿丝袜亚洲一区| 日本亚洲自拍| 国产成人日日夜夜| 成人羞羞国产免费网站| 综合激情成人伊人| 国产专区在线播放| 日韩av影视综合网| 一区二区三区| 国产精品视频精品视频| 在线成人av| 黄色影视在线观看| 中文无字幕一区二区三区| 香港经典三级在线| 欧美日韩mp4| 欧美另类激情| 国产精品女人网站| 狂野欧美性猛交xxxx巴西| 日本中文字幕在线视频观看 | 亚洲欧美日本另类| 精品三级久久久| 国产日韩亚洲欧美| 免费在线成人网| 九九九在线观看视频| 欧美少妇一区二区| 久久九九精品视频| 超碰97国产在线| 国产黑丝在线一区二区三区| 丁香婷婷自拍| 欧美一区二区三区人| 日韩三级成人| 99久久精品免费看国产一区二区三区| 国产最新精品免费| 天天草夜夜草| 亚洲香蕉伊综合在人在线视看| blacked蜜桃精品一区| 日本丰满少妇黄大片在线观看| 一区二区三区欧美在线观看| av中文资源在线资源免费观看| 国模极品一区二区三区| 日日摸夜夜添夜夜添国产精品| 黄色资源在线看| 亚洲乱码一区av黑人高潮| 欧美岛国激情| 国产又大又黄又粗的视频| 欧美一区二区三区日韩视频| 精品国产一区二区三区久久久蜜臀| 亚洲资源视频| 性做久久久久久免费观看欧美| 欧美gv在线观看| 亚洲xxxxx| 久久精品视频一区二区| 激情国产在线| 久久国产欧美精品| 亚洲电影第三页| 中文字幕一区日韩精品| 一区二区三区在线视频111| 色欲综合视频天天天| 欧美精品影院| 国产免费xxx| 欧美一区二区三区在| 久久综合成人| 成人免费视频久久| 亚洲欧美变态国产另类| 国产午夜精品一区二区三区欧美| 影音先锋另类| 88xx成人精品| 久久久久久**毛片大全| 日韩电影免费观看高清完整版| 欧美二区在线看| 欧美日韩综合色| 欧美激情91| 伊人网在线观看| 国产97免费视| 最新国产の精品合集bt伙计| 免费a级人成a大片在线观看| 亚洲精品久久久久久一区二区| 日韩在线一二三区| p色视频免费在线观看| 国产一区二区日韩| 一呦二呦三呦精品国产| 国产精品爱久久久久久久| 毛片不卡一区二区| 成人亚洲综合天堂| 最新av在线免费观看| 亚洲18女电影在线观看| 欧美激情影院| 欧美大尺度做爰床戏| 欧美成人中文字幕在线| 91麻豆国产精品久久| 亚洲青青久久| 国产亚洲天堂网| 超碰97人人做人人爱少妇| 99re热视频精品| 久久在线观看| 网站一区二区三区| 91精品国产免费久久久久久 | 丝袜脚交一区二区| 在线欧美三级| 国产又爽又黄ai换脸| 亚洲一二三在线| 91麻豆精品视频| 爱高潮www亚洲精品| 91在线观看入口| 国产日韩综合一区二区性色av| 亚洲成人激情av| 亚洲性视频h| а√中文在线8| 亚洲最大色综合成人av| 日韩电影中文字幕一区| 国内成+人亚洲+欧美+综合在线| 在线观看的黄色| 成人一区二区免费视频| 免费91在线视频| 一区二区三区欧美视频| 亚洲国内欧美| 国产精品粉嫩| 日本久久精品一区二区| 亲子乱一区二区三区电影 | 婷婷综合电影| 台湾av在线二三区观看| 蜜桃视频在线观看91| 亚洲一区二区黄| 综合激情成人伊人| 亚洲韩日在线| 亚洲精品一区| 亚洲综合在线网站| 91影视免费在线观看| 亚洲高清一区二| 国产欧美日本一区视频| 天天色天天射综合网| 国产福利在线免费观看| 亚洲色欲综合一区二区三区| 国产99久久精品一区二区| 欧美蜜桃一区二区三区| 91蜜桃免费观看视频| 亚洲精品国产成人影院| 亚洲精品日产| 亚洲一区日韩精品| 国产精品传媒毛片三区| 日韩电影大全免费观看2023年上| 国产欧美综合色| 欧美体内she精视频在线观看| 成人全视频在线观看在线播放高清| 开心快乐六月丁香婷婷| 亚洲人成网站在线观看播放| 8090成年在线看片午夜| 精品久久五月天| 亚洲精品欧美专区| 国产一区不卡在线| 亚洲精品一区二区妖精| 欧美视频精品| 素人av在线| 第四色亚洲色图| 精品国产一区二区三区在线| 91九色单男在线观看| 久久香蕉国产线看观看网| 欧美二区在线观看|