平常我们使用 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
结构来记录,我们来看看其定义:
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
结构的定义可以看出,其每个字段与 top
命令的 CPU 使用率类型一一对应。在内核初始化时,会为每个 CPU 创建一个 cpu_usage_stat
结构,用于统计 CPU 的使用情况。
OK,现在我们来分析下内核是怎么统计 CPU 的使用情况的。
每次执行 时钟中断处理程序
都会调用 account_process_tick
函数进行 CPU 使用情况统计,我们来分析一下 account_process_tick
函数的实现:
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 变量标识当前是否处于执行用户应用程序
if (user_tick) {
// 1. 如果 CPU 在执行用户程序, 那么调用 account_user_time 进行统计
account_user_time(p, cputime_one_jiffy, one_jiffy_scaled);
} else if ((p != rq->idle) || (irq_count() != HARDIRQ_OFFSET)) {
// 2. 如果 CPU 在执行内核代码, 那么调用 account_system_time 进行统计
account_system_time(p, HARDIRQ_OFFSET, cputime_one_jiffy,
one_jiffy_scaled);
} else {
// 3. 否则说明 CPU 在执行 idle 进程(也就是处于空闲状态), 那么调用 account_idle_time 进行统计
account_idle_time(cputime_one_jiffy);
}
}
account_process_tick
函数主要分 3 种情况进行统计,如下:
account_user_time
进行统计。account_system_time
进行统计。account_idle_time
进行统计。下面我们分别对这 3 种统计进行分析。
统计用户程序的执行时间是通过 account_user_time
函数来完成的,我们来看看其实现:
void account_user_time(struct task_struct *p, cputime_t cputime,
cputime_t cputime_scaled)
{
// 获取 CPU 的统计结构(每个CPU一个 cpu_usage_stat 结构)
struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;
cputime64_t tmp;
...
// 分 2 种情况统计 CPU 的使用情况
// 1. 如果进程的 nice 值大于0, 那么将会统计到 nice 字段中
// 2. 如果进程的 nice 值小于等于0, 那么将会统计到 user 字段中
if (TASK_NICE(p) > 0)
cpustat->nice = cputime64_add(cpustat->nice, tmp);
else
cpustat->user = cputime64_add(cpustat->user, tmp);
...
}
account_user_time
函数主要分两种情况统计:
nice
值大于0,那么将会增加到 CPU 统计结构的 nice
字段中。nice
值小于等于0,那么增加到 CPU 统计结构的 user
字段中。这里说明一下进程 nice
值的作用,nice
值越大,说明进程的优先级越低。所以,nice
统计值主要用来统计低优先级进程的占使用 CPU 的情况。也说明了,user
和 nice
统计值都属于执行用户程序的 CPU 时间。
如果在发生时钟中断前,CPU 处于内核态,也就是说在执行内核代码。那么将会调用 account_system_time
函数进行统计,account_system_time
函数实现如下:
void account_system_time(struct task_struct *p, int hardirq_offset,
cputime_t cputime, cputime_t cputime_scaled)
{
// 获取 CPU 的统计结构(每个CPU一个 cpu_usage_stat 结构)
struct cpu_usage_stat *cpustat = &kstat_this_cpu.cpustat;
cputime64_t tmp;
...
// 主要分 3 种情况进行统计
// 1. 如果当前处于硬中断执行上下文, 那么统计到 irq 字段中
// 2. 如果当前处于软中断执行上下文, 那么统计到 softirq 字段中
// 3. 否则统计到 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
函数主要分 3 种情况进行统计:
irq
字段中。softirq
字段中。system
字段中。从上面代码可以看出,irq
和 softirq
统计值也算是内核代码执行时间。
当系统中没有可运行的进程时,将会执行 idle
进程。也就是说,当系统执行 idle
进程时,表示系统正处于空闲状态。
idle
进程执行时间统计由 account_idle_time
函数完成,其实现如下:
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 种情况统计 CPU 的使用情况
// 1. 如果系统有进程正在等待 I/O 操作完成, 那么将统计到 iowait 字段中
// 2. 否则将统计到 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
函数也分两种情况进行统计:
iowait
字段中。idle
字段中。从上面的分析可以看出,iowait
统计值也属于空闲时间的一种。
通过源码分析,我们知道 top
命令中 CPU 使用率各种类型的意思,现在我们来介绍一下 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
...
上面的结果显示了 CPU 的使用情况信息,第一行代表所有 CPU 的总和,而第二行开始表示每个 CPU 核心的使用情况信息。因为我的电脑只有一个核,所以只有一条数据。
下面说说这些数据的意义,从第一个数值开始分别代表: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总时间
嗯,看起来还是挺简单的。
本文主要分析了 top
命令中的 CPU 使用率的意义和实现原理,希望通过本文,能够帮助大家对 top
命令有更深的认识。
本文由哈喽比特于3年以前收录,如有侵权请联系我们。
文章来源:https://mp.weixin.qq.com/s/cVjV447AOcxkA7CLv3SIug
京东创始人刘强东和其妻子章泽天最近成为了互联网舆论关注的焦点。有关他们“移民美国”和在美国购买豪宅的传言在互联网上广泛传播。然而,京东官方通过微博发言人发布的消息澄清了这些传言,称这些言论纯属虚假信息和蓄意捏造。
日前,据博主“@超能数码君老周”爆料,国内三大运营商中国移动、中国电信和中国联通预计将集体采购百万台规模的华为Mate60系列手机。
据报道,荷兰半导体设备公司ASML正看到美国对华遏制政策的负面影响。阿斯麦(ASML)CEO彼得·温宁克在一档电视节目中分享了他对中国大陆问题以及该公司面临的出口管制和保护主义的看法。彼得曾在多个场合表达了他对出口管制以及中荷经济关系的担忧。
今年早些时候,抖音悄然上线了一款名为“青桃”的 App,Slogan 为“看见你的热爱”,根据应用介绍可知,“青桃”是一个属于年轻人的兴趣知识视频平台,由抖音官方出品的中长视频关联版本,整体风格有些类似B站。
日前,威马汽车首席数据官梅松林转发了一份“世界各国地区拥车率排行榜”,同时,他发文表示:中国汽车普及率低于非洲国家尼日利亚,每百户家庭仅17户有车。意大利世界排名第一,每十户中九户有车。
近日,一项新的研究发现,维生素 C 和 E 等抗氧化剂会激活一种机制,刺激癌症肿瘤中新血管的生长,帮助它们生长和扩散。
据媒体援引消息人士报道,苹果公司正在测试使用3D打印技术来生产其智能手表的钢质底盘。消息传出后,3D系统一度大涨超10%,不过截至周三收盘,该股涨幅回落至2%以内。
9月2日,坐拥千万粉丝的网红主播“秀才”账号被封禁,在社交媒体平台上引发热议。平台相关负责人表示,“秀才”账号违反平台相关规定,已封禁。据知情人士透露,秀才近期被举报存在违法行为,这可能是他被封禁的部分原因。据悉,“秀才”年龄39岁,是安徽省亳州市蒙城县人,抖音网红,粉丝数量超1200万。他曾被称为“中老年...
9月3日消息,亚马逊的一些股东,包括持有该公司股票的一家养老基金,日前对亚马逊、其创始人贝索斯和其董事会提起诉讼,指控他们在为 Project Kuiper 卫星星座项目购买发射服务时“违反了信义义务”。
据消息,为推广自家应用,苹果现推出了一个名为“Apps by Apple”的网站,展示了苹果为旗下产品(如 iPhone、iPad、Apple Watch、Mac 和 Apple TV)开发的各种应用程序。
特斯拉本周在美国大幅下调Model S和X售价,引发了该公司一些最坚定支持者的不满。知名特斯拉多头、未来基金(Future Fund)管理合伙人加里·布莱克发帖称,降价是一种“短期麻醉剂”,会让潜在客户等待进一步降价。
据外媒9月2日报道,荷兰半导体设备制造商阿斯麦称,尽管荷兰政府颁布的半导体设备出口管制新规9月正式生效,但该公司已获得在2023年底以前向中国运送受限制芯片制造机器的许可。
近日,根据美国证券交易委员会的文件显示,苹果卫星服务提供商 Globalstar 近期向马斯克旗下的 SpaceX 支付 6400 万美元(约 4.65 亿元人民币)。用于在 2023-2025 年期间,发射卫星,进一步扩展苹果 iPhone 系列的 SOS 卫星服务。
据报道,马斯克旗下社交平台𝕏(推特)日前调整了隐私政策,允许 𝕏 使用用户发布的信息来训练其人工智能(AI)模型。新的隐私政策将于 9 月 29 日生效。新政策规定,𝕏可能会使用所收集到的平台信息和公开可用的信息,来帮助训练 𝕏 的机器学习或人工智能模型。
9月2日,荣耀CEO赵明在采访中谈及华为手机回归时表示,替老同事们高兴,觉得手机行业,由于华为的回归,让竞争充满了更多的可能性和更多的魅力,对行业来说也是件好事。
《自然》30日发表的一篇论文报道了一个名为Swift的人工智能(AI)系统,该系统驾驶无人机的能力可在真实世界中一对一冠军赛里战胜人类对手。
近日,非营利组织纽约真菌学会(NYMS)发出警告,表示亚马逊为代表的电商平台上,充斥着各种AI生成的蘑菇觅食科普书籍,其中存在诸多错误。
社交媒体平台𝕏(原推特)新隐私政策提到:“在您同意的情况下,我们可能出于安全、安保和身份识别目的收集和使用您的生物识别信息。”
2023年德国柏林消费电子展上,各大企业都带来了最新的理念和产品,而高端化、本土化的中国产品正在不断吸引欧洲等国际市场的目光。
罗永浩日前在直播中吐槽苹果即将推出的 iPhone 新品,具体内容为:“以我对我‘子公司’的了解,我认为 iPhone 15 跟 iPhone 14 不会有什么区别的,除了序(列)号变了,这个‘不要脸’的东西,这个‘臭厨子’。