日B视频 亚洲,啪啪啪网站一区二区,91色情精品久久,日日噜狠狠色综合久,超碰人妻少妇97在线,999青青视频,亚洲一区二卡,让本一区二区视频,日韩网站推荐

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

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

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

top命令中CPU使用率的意義

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

掃碼添加小助手

加入工程師交流群

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

下面,我們來(lái)介紹一下這些 CPU 使用率的意義:

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

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

ni:nice time,具有優(yōu)先級(jí)的用戶(hù)進(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í)間來(lái)等待 IO 操作,否則就說(shuō)明 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)然,單靠上面的解釋來(lái)理解它們的意義還是比較困難的。所以,本文主要從源碼的角度來(lái)分析它們到底代表什么。

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

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

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

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

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)的定義可以看出,其每個(gè)字段與 top 命令的 CPU 使用率類(lèi)型一一對(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)在我們來(lái)分析下內(nèi)核是怎么統(tǒng)計(jì) CPU 的使用情況的。

每次執(zhí)行 時(shí)鐘中斷處理程序 都會(huì)調(diào)用 account_process_tick 函數(shù)進(jìn)行 CPU 使用情況統(tǒng)計(jì),我們來(lái)分析一下 account_process_tick 函數(shù)的實(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();

// 說(shuō)明:user_tick 變量標(biāo)識(shí)當(dāng)前是否處于執(zhí)行用戶(hù)應(yīng)用程序

if (user_tick) {

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

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 進(jìn)行統(tǒng)計(jì)

account_system_time(p, HARDIRQ_OFFSET, cputime_one_jiffy,

one_jiffy_scaled);

} else {

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

account_idle_time(cputime_one_jiffy);

}

}

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

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

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

否則說(shuō)明 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ì)用戶(hù)程序執(zhí)行時(shí)間

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

void account_user_time(struct task_struct *p, cputime_t cputime,

cputime_t cputime_scaled)

{

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

struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;

cputime64_t tmp;

。..

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

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

// 2. 如果進(jìn)程的 nice 值小于等于0, 那么將會(huì)統(tǒng)計(jì)到 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)計(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 字段中。

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

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

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

void account_system_time(struct task_struct *p, int hardirq_offset,

cputime_t cputime, cputime_t cputime_scaled)

{

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

struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;

cputime64_t tmp;

。..

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

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

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

// 3. 否則統(tǒng)計(jì)到 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 種情況進(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)中沒(méi)有可運(yùn)行的進(jìn)程時(shí),將會(huì)執(zhí)行 idle 進(jìn)程。也就是說(shuō),當(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)如下:

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)計(jì) CPU 的使用情況

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

// 2. 否則將統(tǒng)計(jì)到 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ù)也分兩種情況進(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 使用率通過(guò)源碼分析,我們知道 top 命令中 CPU 使用率各種類(lèi)型的意思,現(xiàn)在我們來(lái)介紹一下 top 命令是怎么計(jì)算各種類(lèi)型的 CPU 使用率。

要獲取各個(gè) CPU 的使用情況信息,可以通過(guò)讀取 /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 的總和,而第二行開(kāi)始表示每個(gè) CPU 核心的使用情況信息。因?yàn)槲业?a href="http://m.sdkjxy.cn/v/tag/1247/" target="_blank">電腦只有一個(gè)核,所以只有一條數(shù)據(jù)。

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

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

CPU總時(shí)間 = user + nice + system + idle + wait + irq + softirq + steal

%us = user / CPU總時(shí)間

%ni = nice / CPU總時(shí)間

%sy = system / CPU總時(shí)間

%id = idel / CPU總時(shí)間

%wa = wait / CPU總時(shí)間

%hi = irq / CPU總時(shí)間

%si = softirq / CPU總時(shí)間

%st = steal / CPU總時(shí)間

嗯,看起來(lái)還是挺簡(jiǎn)單的。

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

責(zé)任編輯:haq

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

    關(guān)注

    68

    文章

    11332

    瀏覽量

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

    關(guān)注

    5

    文章

    759

    瀏覽量

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

    關(guān)注

    0

    文章

    37

    瀏覽量

    33343

原文標(biāo)題:聊聊 top 命令中的 CPU 使用率

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    Linux系統(tǒng)這三個(gè)命令的完整功能和正確查看方法

    在 Linux 系統(tǒng)的日常運(yùn)維,監(jiān)控進(jìn)程資源使用情況是最頻繁的工作之一。當(dāng)服務(wù)器 CPU 突然飆高、內(nèi)存告警、或者業(yè)務(wù)響應(yīng)變慢時(shí),運(yùn)維工程師首先要做的事情就是查看系統(tǒng)資源使用狀況。top、ps、free 這三個(gè)
    的頭像 發(fā)表于 04-21 11:45 ?210次閱讀

    搭載RISC-V芯片F(xiàn)edora操作系統(tǒng),安裝好perf工具之后,輸入pef top -g -e cpu-clock 無(wú)法顯示內(nèi)核函數(shù)的符號(hào)?

    輸入pef top -g -e cpu-clock,終端上顯示 A vmlinux file was not found. Kernel samples will not be resolved.
    發(fā)表于 03-27 08:27

    基于Arm架構(gòu)服務(wù)器釋放更高CPU用率

    在大型云服務(wù)提供商的數(shù)據(jù)中心中,CPU用率長(zhǎng)期偏低,造成了大量資源閑置。根據(jù) CAST AI 的分析,超過(guò) 1,000 個(gè) CPU 的大型集群平均占用率僅約 17%[1],不同云服
    的頭像 發(fā)表于 03-24 10:19 ?572次閱讀

    Linux服務(wù)器CPU飆高怎么排查

    線上 CPU 飆高最怕兩件事:一是盯著 top 看了半小時(shí),最后還是不知道是誰(shuí)打滿了核;二是誤把負(fù)載高當(dāng)成 CPU 高,處理動(dòng)作做反了,越處理越抖。生產(chǎn)環(huán)境里,CPU 問(wèn)題通常不是單一
    的頭像 發(fā)表于 03-11 09:48 ?431次閱讀

    MOSFET 失效 Top 原因

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

    NVMe高速傳輸之?dāng)[脫XDMA設(shè)計(jì)45:上板資源占用率分析

    Block Design 設(shè)計(jì)后進(jìn)行綜合與實(shí)現(xiàn), NoP 邏輯加速引擎的在不同 FPGA 平臺(tái)中的資源占用率分別如表 1 和表 2 所示。 從表可以看到, 本課題設(shè)計(jì)的 NoP邏輯加速引擎資源
    發(fā)表于 11-13 08:36

    modelsim跑tb_top.v報(bào)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ǔ)入門(mén)-其它shell命令

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

    Nginx高并發(fā)場(chǎng)景下的性能調(diào)優(yōu)技巧

    在一次雙十一大促,我們的電商平臺(tái)在活動(dòng)開(kāi)始后3分鐘內(nèi)涌入了800萬(wàn)用戶(hù),QPS瞬間飆升到50萬(wàn)。就在所有人都捏著一把汗的時(shí)候,經(jīng)過(guò)優(yōu)化的Nginx集群穩(wěn)穩(wěn)地扛住了這波流量沖擊,CPU使用率始終保持在60%以下。
    的頭像 發(fā)表于 09-02 16:26 ?1038次閱讀

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

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

    一文掌握Linux命令

    作為一名運(yùn)維工程師,熟練掌握Linux命令是基本功的基本功。無(wú)論是日常工作的系統(tǒng)維護(hù),還是面試時(shí)的技術(shù)考核,Linux命令都是繞不開(kāi)的核心技能。本文將從實(shí)戰(zhàn)角度出發(fā),系統(tǒng)梳理運(yùn)維工
    的頭像 發(fā)表于 07-22 15:23 ?746次閱讀

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

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

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

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

    allegro軟件走線命令下參數(shù)不顯示如何解決

    在PCB設(shè)計(jì),走線命令是頻繁使用的功能之一。執(zhí)行走線命令后,通常會(huì)在Options面板顯示線寬、層、角度等設(shè)置選項(xiàng),用于調(diào)整走線參數(shù)。然而,有時(shí)執(zhí)行走線
    的頭像 發(fā)表于 06-05 09:30 ?2380次閱讀
    allegro軟件走線<b class='flag-5'>命令</b>下參數(shù)不顯示如何解決

    用于攝像頭模塊的 Open Top QFN 插槽Ironwood Electronics

    用于攝像頭模塊的 Open Top QFN 插槽Ironwood Electronics開(kāi)頂式生產(chǎn)插座的另一個(gè)示例使用沖壓彈簧銷(xiāo),其耐用性為 500K 次循環(huán)。QFN 模塊中間有光 IC,在測(cè)試過(guò)程
    發(fā)表于 05-09 09:11
    三亚市| 呈贡县| 清原| 河北省| 新龙县| 鹿泉市| 临汾市| 赣榆县| 潍坊市| 沂源县| 聂拉木县| 石首市| 灵石县| 昌邑市| 砀山县| 邻水| 福海县| 河北省| 博爱县| 临桂县| 乐都县| 南丰县| 沙洋县| 墨脱县| 射阳县| 祁阳县| 峡江县| 天气| 老河口市| 永泰县| 恭城| 云阳县| 高碑店市| 微博| 建水县| 蒲江县| 南开区| 潮安县| 青龙| 富蕴县| 台前县|