(三)Linux性能优化-CPU-CPU 使用率

CPU使用率

  • user(通常缩写为 us),代表用户态 CPU 时间。注意,它不包括下面的 nice 时间,但包括了 guest 时间。
  • nice(通常缩写为 ni),代表低优先级用户态 CPU 时间,也就是进程的 nice 值被调整为 1-19 之间时的 CPU 时间。这里注意,nice 可取值范围是 -20 到 19,数值越大,优先级反而越低。
  • system(通常缩写为 sys),代表内核态 CPU 时间
  • idle(通常缩写为 id),代表空闲时间。注意,它不包括等待 I/O 的时间(iowait)。
  • iowait(通常缩写为 wa),代表等待 I/O 的 CPU 时间
  • irq(通常缩写为 hi),代表处理硬中断的 CPU 时间
  • softirq(通常缩写为 si),代表处理软中断的 CPU 时间
  • steal(通常缩写为 st),代表当系统运行在虚拟机中的时候,被其他虚拟机占用的 CPU 时间
  • guest(通常缩写为 guest),代表通过虚拟化运行其他操作系统的时间,也就是运行虚拟机的 CPU 时间
  • guest_nice(通常缩写为 gnice),代表以低优先级运行虚拟机的时间

每个进程都有一个 %CPU 列,表示进程的 CPU 使用率。它是用户态和内核态 CPU 使用率的总和,包括进程用户空间使用的 CPU、通过系统调用执行的内核空间 CPU 、以及在就绪队列等待运行的 CPU。在虚拟化环境中,它还包括了运行虚拟机占用的 CPU。

CPU 使用率,就是除了空闲时间外的其他时间占总 CPU 时间的百分比,性能分析工具给出的都是间隔一段时间的平均 CPU 使用率,所以要注意间隔时间的设置

perf

通过上述方法很容易找到cpu使用率高的进程,但是具体是进程哪一行代码,则需要新的工具,用perf,这个后面再更新,省的误人子弟

案例

  1. CPU达到100%时候,找到目标进程,然后perf分析代码,确定问题行

  2. CPU使用率很高,但是找不到目标进程,一是可能短进程,二是可能进程不停崩溃重启

  3. 系统出现大量不可中断进程和僵尸进程,

    shell 复制代码
    dstat -cydsgmnplt	查看系统IO情况
    pidstat -d 1 10
    perf record -g

    不可中断进程,就去查看进程IO部分代码,观察代码是读 or 写 的问题
    僵尸进程,找到父进程后,找到其wait或者waitpid代码是否存在,一般僵尸进程是其父进程没有进行回收导致的

相关推荐
威迪斯特18 分钟前
CentOS图形化操作界面:理论解析与实践指南
linux·运维·centos·组件·图形化·桌面·xserver
一方热衷.24 分钟前
在线安装对应版本NVIDIA驱动
linux·运维·服务器
独自归家的兔27 分钟前
ubuntu系统安装dbswitch教程 - 备份本地数据到远程服务器
linux·运维·ubuntu
m0_6948455727 分钟前
tinylisp 是什么?超轻量 Lisp 解释器编译与运行教程
服务器·开发语言·云计算·github·lisp
ONE_SIX_MIX29 分钟前
ubuntu 24.04 用rdp连接,桌面黑屏问题,解决
linux·运维·ubuntu
龙飞0530 分钟前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
*小海豚*31 分钟前
在linux服务器上DNS正常,但是java应用调用第三方解析域名报错
java·linux·服务器
June`31 分钟前
muduo项目排查错误+测试
linux·c++·github·muduo网络库
春日见32 分钟前
如何创建一个PR
运维·开发语言·windows·git·docker·容器
DARLING Zero two♡41 分钟前
告别 Docker 命令行!Portainer+cpolar 让容器管理从局域网走向公网
运维·docker·容器