chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

top命令中CPU使用率的意義

開關(guān)電源芯片 ? 來源:Linux內(nèi)核那些事 ? 作者:songsong001 ? 2021-09-01 14:41 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

us:user time,表示 CPU 執(zhí)行用戶進程的時間,包括 nice 時間。通常都是希望用戶空間CPU越高越好。

sy:system time,表示 CPU 在內(nèi)核運行的時間,包括 IRQ 和 softirq。系統(tǒng) CPU 占用越高,表明系統(tǒng)某部分存在瓶頸。通常這個值越低越好。

ni:nice time,具有優(yōu)先級的用戶進程執(zhí)行時占用的 CPU 利用率百分比。

id:idle time,表示系統(tǒng)處于空閑期,等待進程運行。

wa:waiting time,表示 CPU 在等待 IO 操作完成所花費的時間。系統(tǒng)不應(yīng)該花費大量的時間來等待 IO 操作,否則就說明 IO 存在瓶頸。

hi:hard IRQ time,表示系統(tǒng)處理硬中斷所花費的時間。

si:soft IRQ time,表示系統(tǒng)處理軟中斷所花費的時間。

st:steal time,被強制等待(involuntary wait)虛擬 CPU 的時間,此時 Hypervisor 在為另一個虛擬處理器服務(wù)。

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

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

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

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

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

struct cpu_usage_stat {

cputime64_t user;

cputime64_t nice;

cputime64_t system;

cputime64_t softirq;

cputime64_t irq;

cputime64_t idle;

cputime64_t iowait;

cputime64_t steal;

cputime64_t guest;

};

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

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

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

void account_process_tick(struct task_struct *p, int user_tick)

{

cputime_t one_jiffy_scaled = cputime_to_scaled(cputime_one_jiffy);

struct rq *rq = this_rq();

// 說明:user_tick 變量標識當前是否處于執(zhí)行用戶應(yīng)用程序

if (user_tick) {

// 1. 如果 CPU 在執(zhí)行用戶程序, 那么調(diào)用 account_user_time 進行統(tǒng)計

account_user_time(p, cputime_one_jiffy, one_jiffy_scaled);

} else if ((p != rq-》idle) || (irq_count() != HARDIRQ_OFFSET)) {

// 2. 如果 CPU 在執(zhí)行內(nèi)核代碼, 那么調(diào)用 account_system_time 進行統(tǒng)計

account_system_time(p, HARDIRQ_OFFSET, cputime_one_jiffy,

one_jiffy_scaled);

} else {

// 3. 否則說明 CPU 在執(zhí)行 idle 進程(也就是處于空閑狀態(tài)), 那么調(diào)用 account_idle_time 進行統(tǒng)計

account_idle_time(cputime_one_jiffy);

}

}

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

如果 CPU 在執(zhí)行用戶程序,那么調(diào)用 account_user_time 進行統(tǒng)計。

如果 CPU 在執(zhí)行內(nèi)核代碼,那么調(diào)用 account_system_time 進行統(tǒng)計。

否則說明 CPU 在執(zhí)行 idle 進程(也就是處于空閑狀態(tài)),那么調(diào)用 account_idle_time 進行統(tǒng)計。

CPU 使用情況統(tǒng)計下面我們分別對這 3 種統(tǒng)計進行分析。

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

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

void account_user_time(struct task_struct *p, cputime_t cputime,

cputime_t cputime_scaled)

{

// 獲取 CPU 的統(tǒng)計結(jié)構(gòu)(每個CPU一個 cpu_usage_stat 結(jié)構(gòu))

struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;

cputime64_t tmp;

。..

// 分 2 種情況統(tǒng)計 CPU 的使用情況

// 1. 如果進程的 nice 值大于0, 那么將會統(tǒng)計到 nice 字段中

// 2. 如果進程的 nice 值小于等于0, 那么將會統(tǒng)計到 user 字段中

if (TASK_NICE(p) 》 0)

cpustat-》nice = cputime64_add(cpustat-》nice, tmp);

else

cpustat-》user = cputime64_add(cpustat-》user, tmp);

。..

}

account_user_time 函數(shù)主要分兩種情況統(tǒng)計:

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

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

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

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

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

void account_system_time(struct task_struct *p, int hardirq_offset,

cputime_t cputime, cputime_t cputime_scaled)

{

// 獲取 CPU 的統(tǒng)計結(jié)構(gòu)(每個CPU一個 cpu_usage_stat 結(jié)構(gòu))

struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;

cputime64_t tmp;

。..

// 主要分 3 種情況進行統(tǒng)計

// 1. 如果當前處于硬中斷執(zhí)行上下文, 那么統(tǒng)計到 irq 字段中

// 2. 如果當前處于軟中斷執(zhí)行上下文, 那么統(tǒng)計到 softirq 字段中

// 3. 否則統(tǒng)計到 system 字段中

if (hardirq_count() - hardirq_offset)

cpustat-》irq = cputime64_add(cpustat-》irq, tmp);

else if (softirq_count())

cpustat-》softirq = cputime64_add(cpustat-》softirq, tmp);

else

cpustat-》system = cputime64_add(cpustat-》system, tmp);

。..

}

account_system_time 函數(shù)主要分 3 種情況進行統(tǒng)計:

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

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

否則增加到 CPU 統(tǒng)計結(jié)構(gòu)的 system 字段中。

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

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

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

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

void account_idle_time(cputime_t cputime)

{

struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;

cputime64_t cputime64 = cputime_to_cputime64(cputime);

struct rq *rq = this_rq();

// 分 2 種情況統(tǒng)計 CPU 的使用情況

// 1. 如果系統(tǒng)有進程正在等待 I/O 操作完成, 那么將統(tǒng)計到 iowait 字段中

// 2. 否則將統(tǒng)計到 idle 字段中

if (atomic_read(&rq-》nr_iowait) 》 0)

cpustat-》iowait = cputime64_add(cpustat-》iowait, cputime64);

else

cpustat-》idle = cputime64_add(cpustat-》idle, cputime64);

}

account_idle_time 函數(shù)也分兩種情況進行統(tǒng)計:

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

否則增加到 CPU 統(tǒng)計結(jié)構(gòu)的 idle 字段中。

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

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

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

[vagrant@localhost ~]$ cat /proc/stat

cpu 245 10 1142 1097923 95 0 28 0 0 0

cpu0 245 10 1142 1097923 95 0 28 0 0 0

。..

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

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

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

CPU總時間 = user + nice + system + idle + wait + irq + softirq + steal

%us = user / CPU總時間

%ni = nice / CPU總時間

%sy = system / CPU總時間

%id = idel / CPU總時間

%wa = wait / CPU總時間

%hi = irq / CPU總時間

%si = softirq / CPU總時間

%st = steal / CPU總時間

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

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

責(zé)任編輯:haq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11250

    瀏覽量

    223836
  • 命令
    +關(guān)注

    關(guān)注

    5

    文章

    747

    瀏覽量

    23558
  • TOP
    TOP
    +關(guān)注

    關(guān)注

    0

    文章

    37

    瀏覽量

    33207

原文標題:聊聊 top 命令中的 CPU 使用率

文章出處:【微信號:gh_3980db2283cd,微信公眾號:開關(guān)電源芯片】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    MOSFET 失效 Top 原因

    匹配。根據(jù)FAE現(xiàn)場統(tǒng)計,80%的MOSFET失效并非器件質(zhì)量問題,而是設(shè)計與應(yīng)用問題。本文聚焦Top10的前5項來看看:電氣設(shè)計相關(guān)失效的原因。一、TOP1:V
    的頭像 發(fā)表于 01-20 15:29 ?69次閱讀
    MOSFET 失效 <b class='flag-5'>Top</b> 原因

    modelsim跑tb_top.v報fatal是什么原因?qū)е碌??如何解決?

    : tb_top.u_e203_soc_top.u_e203_subsys_top.u_e203_subsys_main.u_e203_cpu_top.u_e203_cpu
    發(fā)表于 11-10 06:16

    飛凌嵌入式ElfBoard-Linux系統(tǒng)基礎(chǔ)入門-其它shell命令

    :~$ kill -9 110746top動態(tài)顯示命令命令top功能:動態(tài)顯示當前系統(tǒng)由該用戶運行的進程列表參數(shù):無elf@ubuntu
    發(fā)表于 10-11 08:42

    Linux基礎(chǔ)命令which詳解

    在Linux系統(tǒng),which命令用于查找并顯示指定命令的可執(zhí)行文件路徑。這對于系統(tǒng)管理員和開發(fā)人員來說是一個非常有用的工具,可以幫助定位命令所在的位置,確認
    的頭像 發(fā)表于 07-29 17:58 ?752次閱讀

    詳解Linux網(wǎng)絡(luò)管理的關(guān)鍵命令

    本文檔概述了網(wǎng)絡(luò)管理的關(guān)鍵命令,如ifconfig配置網(wǎng)絡(luò)接口,ip管理路由,ping測試連通性,以及nmap進行安全掃描。還介紹了nslookup和dig用于域名解析,tcpdump抓包分析,以及arp操作和nmap的深入應(yīng)用。
    的頭像 發(fā)表于 07-04 11:37 ?765次閱讀
    詳解Linux網(wǎng)絡(luò)管理<b class='flag-5'>中</b>的關(guān)鍵<b class='flag-5'>命令</b>

    飛凌嵌入式ElfBoard ELF 1板卡-文件系統(tǒng)常用命令之磁盤管理與維護常用命令

    一、df:查看系統(tǒng)已用空間df命令,用于顯示linux系統(tǒng)各文件系統(tǒng)的硬盤使用情況。包括文件系統(tǒng)所在硬盤分區(qū)的總?cè)萘?、已使用的容量、剩余容量等。用法:df [OPTION]... [FILE
    發(fā)表于 06-24 11:26

    5個Linux性能監(jiān)控命令

    vmstat 命令可打印有關(guān)內(nèi)存、交換、I/O 和 CPU 活動的詳細報告。其中包括已用/可用內(nèi)存、交換入/出、磁盤塊讀/寫和 CPU 進程/閑置時間等指標。
    的頭像 發(fā)表于 04-09 10:34 ?695次閱讀

    在MR-VMU-RT1176上運行的PX4飛行控制軟件的負載(大約)是多少?

    我想知道在 MR-VMU-RT1176 上運行的 PX4 飛行控制軟件的負載(大約)是多少,包括 RAM 使用率、FLASH 使用率、CPU 負載(可能很難說! 我需要通過以太網(wǎng)和 USB 開發(fā)其他任務(wù),因此我想知道添加代碼有多
    發(fā)表于 04-03 06:18

    服務(wù)器使用過程卡頓如何排查

    技巧,希望能有所幫助。 服務(wù)器卡頓的情況下,請先檢查服務(wù)器的使用情況。 ?1、CPU使用率是否大于50%。 ?2、內(nèi)存使用率是否過高。 ?3、網(wǎng)絡(luò)使用率是否過高。 如果出現(xiàn)上述情況,請
    的頭像 發(fā)表于 03-31 17:04 ?1063次閱讀

    TECS OpenStack資源池主機磁盤分區(qū)使用率過高的問題處理

    某運營商TECS資源池上報“主機磁盤分區(qū)使用率過高”的告警,如下圖所示。
    的頭像 發(fā)表于 03-21 09:47 ?922次閱讀
    TECS OpenStack資源池主機磁盤分區(qū)<b class='flag-5'>使用率</b>過高的問題處理

    東京物理服務(wù)器的價格是如何影響用戶的使用率

    東京物理服務(wù)器的價格對用戶的使用率有顯著影響,主要體現(xiàn)在以下幾個方面,主機推薦小編為您整理發(fā)布東京物理服務(wù)器的價格是如何影響用戶的使用率。
    的頭像 發(fā)表于 02-24 09:16 ?619次閱讀

    HarmonyOS NEXT 原生應(yīng)用/元服務(wù)-DevEco Profiler性能問題定界實時監(jiān)控

    ,該能力為您提供全方位的設(shè)備資源監(jiān)測,覆蓋系統(tǒng)事件、異常報告、CPU占用、內(nèi)存占用、實時幀率、GPU使用率、溫度、電流以及能耗等多個維度的數(shù)據(jù),幫助您初步識別性能瓶頸,定界問題所在。 一、配置并確認
    發(fā)表于 02-21 14:35

    HarmonyOS NEXT 原生應(yīng)用/元服務(wù)-DevEco Profiler性能問題定界實時監(jiān)控

    ,該能力為您提供全方位的設(shè)備資源監(jiān)測,覆蓋系統(tǒng)事件、異常報告、CPU占用、內(nèi)存占用、實時幀率、GPU使用率、溫度、電流以及能耗等多個維度的數(shù)據(jù),幫助您初步識別性能瓶頸,定界問題所在。 一、配置并確認
    發(fā)表于 02-20 10:14

    Linux ip命令常用操作

    Linux?ip命令常用操作 在Linux系統(tǒng),ip命令是用于管理網(wǎng)絡(luò)接口和路由的強大工具。相比于舊的?ifconfig命令,ip命令提供
    的頭像 發(fā)表于 02-19 10:23 ?1236次閱讀

    CPU怎么降頻 bios如何把cpu調(diào)低頻率

    CPU降頻是一種有效的節(jié)能措施,同時也有助于降低設(shè)備的溫度和功耗,提高系統(tǒng)的穩(wěn)定性和使用壽命。以下將詳細介紹如何在操作系統(tǒng)、BIOS設(shè)置里以及使用第三方軟件來實現(xiàn)CPU降頻。 一、在操作系統(tǒng)
    的頭像 發(fā)表于 02-01 15:02 ?3.3w次閱讀