目录

  • CPU使用率
  • 查看CPU使用率(top、pidstat解释)
  • CPU使用率过高
    • perf top
    • perf record 和 perf report

CPU使用率

Linux通过/proc虚拟文件系统,向用户空间提供了系统内部状态的信息。
/proc/stat提供的就是系统的CPU和任务统计信息。
执行命令cat /proc/stat | grep ^cpu,表示只保留各个CPU的数据,结果如下:

输出表示:
第一行表示所有CPU的不同场景下的累加节拍数。
Tips:为了维护 CPU 时间,Linux 通过事先定义的节拍率(内核中表示为 HZ),触发时间中断,并使用全局变量 Jiffies 记录了开机以来的节拍数。每发生一次时间中断,Jiffies 的值就加 1。通过命令grep 'CONFIG_HZ=' /boot/config-$(uname -r)可以查看系统配置的节拍率,即每秒钟触发多少次时间中断。
第一列:CPU编号
接下来的几列:
usr(缩写为us),代表用户态CPU时间。不包含nice时间,包括guest时间
nice(缩写ni),代表低优先级用户态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,代表虚拟化运行其他操作系统的时间,也就是运行虚拟机的CPU时间
guest_nice(缩写为gnice),代表以低优先级运行虚拟机的时间。
CPU使用率的定义则是:

/proc/stat 的数据记录的是开机以来的节拍累积值,所以算出来的是平均CPU使用率。
一般来说,性能工具回取间隔一段时间(如3s)的两次值,作差后,再计算这段时间内的平均CPU使用率:

查看CPU使用率(top、pidstat解释)

关于top与ps:
top 显示了系统总体的 CPU 和内存使用情况,以及各个进程的资源使用情况。
ps 则只显示了每个进程的资源使用情况。
top命令中的第三行%cpu即系统CPU使用率,默认显示的是平均值

空白行之后是进程实时信息,每个进程都有一个%CPU列,表示进程的CPU使用率。该使用率 = 用户态 + 内核态CPU使用率的总和,包括进程用户空间使用的CPU、通过系统调用执行的内核空间CPU、就绪队列等待运行的CPU。
再按1,切换显示每个CPU使用率。

接下来使用pidstat:
包括了:
用户态CPU使用率(%usr)
内核态CPU使用率(%system)
运行虚拟机CPU使用率(%guest)
等待CPU使用率(%wait)
总的CPU使用率(%CPU)
最后输出平均值

# 隔 1 秒 输出一组数据, 共输出5组
pidstat 1 5
21时55分30秒   UID       PID    %usr %system  %guest   %wait    %CPU   CPU  Command
21时55分31秒     0        54    0.00    1.00    0.00    0.00    1.00     7  ksoftirqd/7
21时55分31秒  1000      1311    1.00    0.00    0.00    0.00    1.00     4  gnome-shell
21时55分31秒  1000      3170    0.00    1.00    0.00    0.00    1.00     1  pidstat
...
平均时间:   UID       PID    %usr %system  %guest   %wait    %CPU   CPU  Command
平均时间:     0        54    0.00    0.25    0.00    0.00    0.25     -  ksoftirqd/7
平均时间:     0       135    0.00    0.25    0.00    0.00    0.25     -  kworker/u16:2-phy0
平均时间:  1000       998    0.25    0.25    0.00    0.00    0.50     -  Xorg
平均时间:  1000      1311    1.25    0.50    0.00    0.00    1.75     -  gnome-shell
平均时间:  1000      2370    0.25    0.00    0.00    0.00    0.25     -  chrome
平均时间:  1000      2712    0.75    0.00    0.00    0.00    0.75     -  chrome
平均时间:  1000      3157    0.50    0.00    0.00    0.00    0.50     -  gnome-terminal-
平均时间:  1000      3170    0.25    0.75    0.00    0.00    1.00     -  pidstat

CPU使用率过高

使用perf,它以性能事件采样为基础,可以分析系统的各种事件和内核性能,也可以分析指定应用程序的性能问题。

perf top

类似于top,它能够实时显示占用CPU时钟最多的函数或者指令,因此可以用来查找热点函数。如:

$ perf top
2 Samples: 833
3 Overhead
of event 'cpu-clock', Event count (approx.): 97742399
Shared Object Symbol
4 7.28% perf [.] 0x00000000001f78a4
5 4.72% [kernel] [k] vsnprintf
6 4.32% [kernel] [k] module_get_kallsym
7 3.65% [kernel] [k] _raw_spin_unlock_irqrestore

输出结果解释:
第一行,包含三个数据: 采样数(Samples)、事件类型(event)和事件总数量(Event count)。
下面的表格数据包含四列:
第一列: Overhead,该符号的性能事件在所有采样中的比率
第二列:Shared,该函数或指令所在的动态共享对象,如内核、进程名、动态链接库名、内核模块等
第三列:Object,是动态共享对象的类型,比如[.]表示用户空间的可执行程序,或者动态链接库,[k]表示内核空间。
第四列:Symbol,符号名,即函数名。当函数名未知时,用16进制的地址表示

perf record 和 perf report

perf top 能够实时展示系统性能,但是不能保存数据,也就无法用于离线或者后续的分析。
而perf record 提供了保存数据的功能,保存后的数据,需要使用perf report 来解析展示:

perf record # 按下 ctrl + c 终止采样
[perf record: Woken up 1 times to write data]
[perf record: Captured and wrote 0.452 MB perf.data(6093 samples) ]perf report # 展示类似于perf top的报告

在实际使用中经常为perf top 和 perf record 加上 -g 参数,开启调用关系的采样,方便根据调用链来分析性能。

CPU使用率的查看以及性能分析(perf top/record/report)相关推荐

  1. Linux性能分析工具top命令详解

    top命令是linux下常用的性能分析工具,能够实时的显示系统中各个进程的资源占用情况,常用于服务端性能分析. top命令说明: top命令的结果分为两部分: 统计信息:前五行是系统的整体统计信息. ...

  2. linux 使cpu使用率升高_Linux程序性能优化:CPU的上下文切换

      linux操作系统是将CPU轮流分配给任务,分时执行的.而每次执行任务时,CPU需要知道CPU寄存器(CPU内置的内存)和程序计数器PC(CPU正在执行指令和下一条指令的位置)值,这些值是CPU执 ...

  3. 记最近Linux中遇到cpu使用率低loadavg高的分析过程

    首先明确一下CPU使用率和loadavg这两个概念: CPU使用率 指当前CPU正在执行指令的繁忙程度,越高表面CPU正在执行很多指令即有进程一直在cpu上运行着 Loadavg 指的是CPU负载程度 ...

  4. 查看cpu使用率。查看进程占用cpu百分比

     /proc/ /stat 包含了所有CPU活跃的信息,该文件中的所有值都是从系统启动开始累计到当前时刻. [root@localhost ~]# cat /proc/6873/stat 6873 ( ...

  5. 【linux性能优化】CPU使用率过高分析

    最常用什么指标来描述系统的 CPU 性能呢? 可能不是平均负载,也不是 CPU上下文切换,而是另一个更直观的指标CPU使用率 CPU使用率是单位时间内CPU使用情况的统计,以百分比的方式展示 那么,作 ...

  6. Linux性能优化从入门到实战:04 CPU篇:CPU使用率

      CPU使用率是单位时间内CPU使用情况的统计,以百分比方式展示. $ top top - 11:46:45 up 7 days, 11:52, 1 user, load average: 0.00 ...

  7. CPU性能分析优化套路

    目录 一.CPU性能指标 1.CPU 使用率 2.平均负载 3.进程上下文切换 4.CPU 缓存的命中率 二.CPU性能工具 1.性能工具 2.从性能指标找工具(重点是:思路) 3.从工具理解性能指标 ...

  8. Linux 系统 CPU 使用率简单分析

    CPU 使用率是单位时间内 CPU 使用情况的统计,以百分比的方式展示. CPU 使用率 为了维护 CPU 时间,Linux 通过事先定义的节拍率(内核中表示为 HZ),触发时间中断,并使用全局变量 ...

  9. Linux CPU性能优化 —— CPU使用率及高CPU使用率排查

    文章目录 CPU使用率的定义 查看CPU使用率:top和pidstat 排查高CPU使用率:pref 参考文献 写在前面: 由于之前在开发分布式系统中由于云服务器性能原因,导致系统总是断连等错误.但是 ...

最新文章

  1. Linux(二)各种实用命令
  2. C语言libcurl例程:multi 多线程,多任务
  3. Mybatis框架相关知识讲解
  4. nginx+lua+redis实现post请求接口之黑名单(一)
  5. windows系统bat批处理 bat脚本默认拥有管理员权限
  6. 智能优化算法:蝙蝠算法-附代码
  7. 软考-内存按字节编址,求地址间的存储单元数量(容量)以及芯片个数。
  8. 用计算机探索规律反思,规律的背后——用计算器探索规律教学反思
  9. pdf转换成word转换器免费版哪里下载
  10. 十大思想实验(思维风暴)
  11. Windows中命令行收集
  12. 用于自动驾驶的激光雷达里程计方法综述
  13. Python中字符串的迷幻操作-----驻留机制的理解
  14. 云南省自然保护区分布及功能区划
  15. 栅格数据去除黑边并无缝拼接(envi,arcgis)
  16. 电控系统开发工作内容梳理
  17. vue-draggable学习和使用
  18. TensorFlow.js预测鸢尾花种类
  19. python自动创建sqlserver表并上传dataframe到创建的表中
  20. IDM\FDM下载器使用指南

热门文章

  1. 【TypeScript系列教程01】入门介绍
  2. javaScript学习笔记之比较运算符||逻辑运算符||条件运算符(三目运算符)
  3. java中大数开方_大数开方(Java版)
  4. mysql 快照能否恢复某个表_mysql全库备份恢复某个表
  5. react如何监听路由url变化
  6. iview给radio按钮组件加点击事件
  7. 面试中关于多线程同步,你必须要思考的问题
  8. 如何监视ps/查询的性能和使用
  9. JavaScript实现表单的全选,反选,获取值
  10. 【2017级面向对象程序设计】第2次成绩排行