如何判断CPU忙

作者: mysia | 来源:发表于2019-04-12 15:37 被阅读46次

学习 Linux 时,经常可以看到两个词:User space(用户空间)和 Kernel space(内核空间)。

简单说,Kernel space 是 Linux 内核的运行空间,User space 是用户程序的运行空间。为了安全,它们是隔离的,即使用户的程序崩溃了,内核也不受影响。

CPU

Kernel space 可以执行任意命令,调用系统的一切资源;User space 只能执行简单的运算,不能直接调用系统资源,必须通过系统接口(又称 system call),才能向内核发出指令。

str = "my string" // 用户空间
x =x + 2
file . write(str ) // 切换到内核空间
y =x + 4 // 切换回用户空间

上面代码中,第一行和第二行都是简单的赋值运算,在 User space 执行。第三行需要写入文件,就要切换到 Kernel space,因为用户不能直接写文件,必须通过内核安排。第四行又是赋值运算,就切换回 User space。

查看 CPU 时间在 User space 与 Kernel Space 之间的分配情况,可以使用top命令。它的第三行输出就是 CPU 时间分配统计。

top

这一行有 8 项统计指标:

  • 1.7%us(user的缩写)就是CPU消耗在user space的时间百分比;
  • 2.0%sy(system的缩写)是消耗在kernel space的时间百分比;
  • 0.0%ni(niceness的缩写),CPU 消耗在 nice 进程(低优先级)的时间百分比;
  • 96.1%id(idle 的缩写),CPU 消耗在闲置进程的时间百分比,这个值越低,表示 CPU 越忙;
  • 0.0%wa(wait的缩写),CPU 等待外部 I/O 的时间百分比,这段时间 CPU 不能干其他事,但是也没有执行运算,这个值太高就说明外部设备有问题;
  • 0.0%hi(hardware interrupt的缩写),CPU 响应硬件中断请求的时间百分比;
  • 0.1%si(software interrupt 的缩写),CPU 响应软件中断请求的时间百分比;
  • 0.0%st(stole time 的缩写),该项指标只对虚拟机有效,表示分配给当前虚拟机的 CPU 时间之中,被同一台物理机上的其他虚拟机偷走的时间百分比

如果想查看单个程序的耗时,一般使用time命令。

time

程序名之前加上time命令,会在程序执行完毕以后,默认显示3行统计:

  • real:程序从开始运行到结束的全部时间,这是用户能感知到的时间,包括 CPU 切换去执行其他任务的时间。
  • user:程序在 User space 执行的时间;
  • sys:程序在 Kernel space 执行的时间;

user和sys之和,一般情况下,应该小于real。但如果是多核 CPU,这两个指标反映的是所有 CPU 的总耗时,所以它们之和可能大于real。

相关文章

  • 如何判断CPU忙

    学习 Linux 时,经常可以看到两个词:User space(用户空间)和 Kernel space(内核空间)...

  • zabbix-esxi CPU触发器解释

    判断CPU使用率 CPU使用率的判断不像一般添加的主机需要确定使用量,CPU数,以及频率 进行计算判断CPU负载c...

  • 查看系统负载情况

    1、如何判断系统是否已经Over Load?根据cpu数量去判断。如果平均负载始终在1.2一下,而你有2颗cup的...

  • linux查看cpu、内存、版本信息

    1. 用命令判断几个物理CPU,几个核等 逻辑CPU个数: 物理CPU个数: 2.查看CPU信息命令 3.查看内存...

  • CPU利用率和Load Average

    CPU利用率和Load Average的区别 CPU利用率:CPU利用率在过去常常被我们这些外行认为是判断机器是否...

  • IO密集型的线程池大小设置

    类型判断(CPU密集orIO密集or混合型) 看应用是CPU密集型的还是IO密集型的,还是混合型的。 CPU密集C...

  • 线程

    单核CPU如何执行多任务? 多核CPU如何执行多任务? 真正的并行执行多任务只能在多核CPU上实现,但是,由于任务...

  • C语言判断机器CPU大小端模式的两种方法

    C语言判断机器CPU大小端模式的两种方法 本文介绍使用C语言编写程序判断机器CPU大小端模式的两种方法。 第一种方...

  • Linux 学习基础 -- 相关设备组件

    1.执行运算和判断的CPU 1.1 多核CPU指的是什么? 原本的单核心CPU仅有一个运算单元,所谓的多核心则是在...

  • 如何定位java进程cpu占用过高

    如何定位java进程cpu占用过高 如何定位java进程cpu占用过高,分三步走 根据cpu消耗,打印出pid进程...

网友评论

    本文标题:如何判断CPU忙

    本文链接:https://www.haomeiwen.com/subject/wemcwqtx.html