Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Linux - CPU性能评估_详解查看CPU性能的命令

Linux - CPU性能评估_详解查看CPU性能的命令

作者头像
小小工匠
发布于 2023-03-07 13:38:42
发布于 2023-03-07 13:38:42
8K00
代码可运行
举报
文章被收录于专栏:小工匠聊架构小工匠聊架构
运行总次数:0
代码可运行

文章目录

vmstat命令

vmstat命令可以显示关于系统各种资源之间相关性能的简要信息,这里主要用它来看CPU的一个负载情况。

下面是vmstat命令在某个系统中的输出结果。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@VM-24-3-centos ~]# vmstat  2 3
procs -----------memory---------- ---swap-- -----io---- -system-- ------cpu-----
 r  b   swpd   free   buff  cache   si   so    bi    bo   in   cs us sy id wa st
 1  0      0 223324 144388 1427352    0    0     1    15    1    1  1  0 99  0  0
 0  0      0 222616 144388 1427352    0    0     0    24 1928 3582  1  0 99  0  0
 0  0      0 222848 144388 1427360    0    0     0   664 2121 3895  1  1 98  1  0
[root@VM-24-3-centos ~]#

对上面每项的输出解释如下

  • procs r列表示运行和等待CPU时间片的进程数,这个值如果长期大于系统CPU的个数,说明CPU不足,需要增加CPU。 b列表示在等待资源的进程数,比如正在等待I/O或者内存交换等。
  • memory swpd列表示切换到内存交换区的内存数量(以KB为单位)。如果swpd的值不为0,或者比较大,只要si、so的值长期为0,这种情况下一般就不用担心,它不会影响系统性能。 free列表示当前空闲的物理内存数量(以KB为单位)。 buff列表示缓冲区缓存的内存数量,一般对块设备的读写才需要缓冲。 cache列表示页面缓存的内存数量,一般作为文件系统缓存,频繁访问的文件都会被缓存,如果cache值较大,说明缓存的文件数较多,如果此时IO中bi比较小,说明文件系统效率比较好。
  • swap si列表示由磁盘调入内存,也就是内存进入内存交换区的数量。 so列表示由内存调入磁盘,也就是内存交换区进入内存的数量。 一般情况下,si、so的值都为0。如果si、so的值长期不为0,则表示系统内存不足,需要增加系统内存。
  • io项显示磁盘读写状况。 bi列表示从块设备读入数据的总量(即读磁盘)(每秒KB)。 bo列表示写入到块设备的数据总量(即写磁盘)(每秒KB)。 这里设置的bi+bo参考值为1000,如果超过1000,而且wa值较大,则表示系统磁盘I/O有问题,应该考虑提高磁盘的读写性能。
  • system 显示采集间隔内发生的中断次数。 in列表示在某一时间间隔中观测到的每秒设备中断次数。 cs列表示每秒产生的上下文切换次数。 上面这两个值越大,会看到由内核占用CPU的时间会越多。
  • cpu项显示了CPU的使用状态,此项是我们关注的重点。 us列显示了用户进程占用CPU的时间百分比。us的值比较高时,说明用户进程占用CPU的时间多,但是如果长期大于50%,就需要考虑优化程序或算法。 sy列显示了内核进程占用CPU的时间百分比。sy的值较高时,说明内核消耗的CPU资源很多。 根据经验,us+sy的参考值为80%,如果us+sy大于 80%说明可能存在CPU资源不足。 id 列显示了CPU处在空闲状态的时间百分比。 wa列显示了I/O等待所占用的CPU时间百分比。wa值越高,说明I/O等待越严重。根据经验,wa的参考值为20%。如果wa超过20%,说明I/O等待严重,引起I/O等待的原因可能是磁盘大量随机读写造成的,也可能是磁盘或者磁盘控制器的带宽瓶颈造成的(主要是块操作)。

综上所述,在对CPU的评估中,需要重点注意的是procs项下r列的值和cpu项下us、sy和id列的值。

sar命令

检查CPU性能的第二个工具是sar。sar功能很强大,可以对系统的每个方面进行单独的统计,但是使用sar命令会增加系统开销。不过,这些开销是可以评估的,对系统的统计结果不会有很大影响。

Sar是后台进程sadc的前端显示工具,安装名为“sysstat”的包后,sadc就会自动从内核收集报告并保存。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
 yum install sysstat 

下面是sar命令对某个系统的CPU统计输出。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@VM-24-3-centos ~]# sar -u 3 5

对上面每项的输出解释如下。

  • %user列显示了用户进程占用CPU的时间百分比。
  • %nice列显示了运行正常进程占用CPU的时间百分比。
  • %system列显示了系统进程占用CPU的时间百分比。
  • %iowait列显示了I/O等待所占用CPU的时间百分比
  • %steal列显示了在内存相对紧张的环境下pagein强制对不同的页面进行的steal操作。
  • %idle列显示了CPU处在空闲状态的时间百分比。

这个输出是对系统整体CPU使用状况的统计,每项的输出都非常直观,并且最后一行的Average是个汇总行,是上面统计信息的一个平均值。

需要注意的一点是,第一行的统计信息包含sar本身的统计消耗,所以%user列的值会偏高一点。不过,这不会对统计结果产生多大影响。

在一个多CPU的系统中,如果程序使用单线程,会出现这么一个现象,CPU的整体使用率不高,但是系统应用响应缓慢。这可能是程序使用单线程的原因,单线程只使用一个CPU,导致这个CPU占用率为100%,无法处理其他请求,而其他的CPU却闲置,这就导致了整体CPU使用率不高,而应用缓慢现象的发生。

统计单个CPU的使用情况

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@VM-24-3-centos ~]# sar -P 0 3 5
Linux 3.10.0-1160.11.1.el7.x86_64 (VM-24-3-centos)      03/05/2023      _x86_64_        (2 CPU)

09:35:19 PM     CPU     %user     %nice   %system   %iowait    %steal     %idle
09:35:22 PM       0      0.33      0.00      0.33      0.00      0.00     99.33
09:35:25 PM       0      0.34      0.00      0.34      0.34      0.00     98.99
09:35:28 PM       0      0.67      0.00      0.67      1.34      0.00     97.32
09:35:31 PM       0      0.67      0.00      0.34      0.00      0.00     98.99
09:35:34 PM       0      0.33      0.00      0.33      0.00      0.00     99.33
Average:          0      0.47      0.00      0.40      0.34      0.00     98.79
[root@VM-24-3-centos ~]#

这个输出是对系统的第一颗CPU的信息统计。需要注意的是,sar中对CPU的计数是从0开始的,因此,“sar -P 0 3 5”表示对系统的第1颗CPU进行信息统计,“sar -P 1 3 5”则表示对系统的第2颗CPU进行统计,依次类推。可以看出,上面的系统有2颗CPU。

iostat -c 命令

iostat指令主要用于统计磁盘I/O状态,但是也能查看CPU的使用信息,它的局限性是只能显示系统所有CPU的平均信息。看下面的一个输出。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@VM-24-3-centos ~]# iostat  -c
Linux 3.10.0-1160.11.1.el7.x86_64 (VM-24-3-centos)      03/05/2023      _x86_64_        (2 CPU)

avg-cpu:  %user   %nice %system %iowait  %steal   %idle
           0.55    0.00    0.42    0.06    0.00   98.96

[root@VM-24-3-centos ~]#

这里使用了“-c”参数,只显示系统CPU的统计信息,输出中每项代表的含义与sar命令的输出项完全相同 。

uptime命令

uptime是监控系统性能最常用的一个命令,主要用来统计系统当前的运行状况。输出的信息依次为:系统现在的时间,系统从上次开机到现在运行了多长时间,系统目前有多少登录用户,系统在1分钟内、5分钟内、15分钟内的平均负载。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@VM-24-3-centos ~]# uptime
 21:37:58 up 238 days, 20:48,  4 users,  load average: 0.00, 0.02, 0.05
[root@VM-24-3-centos ~]#

这里需要注意的是load average这个输出值,这三个值的大小一般不能大于系统CPU的个数。例如,本输出中系统有2个CPU,如果load average的三个值长期大于2,就说明CPU很繁忙,负载很高,可能会影响系统性能,但是偶尔大于2时,也不用担心,一般不会影响系统性能。相反,如果load average的输出值小于CPU的个数,则表示CPU还有空闲的时间片,比如本例中的输出,CPU是非常空闲的。

小结

我们这里介绍了检查CPU使用状况的4个命令。通过这些命令可以了解系统CPU是否出现性能瓶颈。也就是说,以上这些命令只能查看CPU是否繁忙,负载是否过大,但是无法知道CPU为何负载过大。

因而,判断系统CPU出现问题后,要结合top、ps等命令进一步检查是由那些进程导致CPU负载过大的。引起CPU资源紧缺的原因可能是应用程序不合理造成的,也可能是硬件资源匮乏引起的,所以,要具体问题具体分析,或者优化应用程序,或者增加系统CPU资源。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-03-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Linux - 内存性能评估
内存的管理和优化是系统性能优化的一个重要部分,内存资源的充足与否直接影响应用系统的使用性能。在进行内存优化之前,一定要熟悉Linux的内存管理机制,这里我们重点探讨如何通过系统命令监控Linux系统的内存使用状况。
小小工匠
2023/03/07
1.9K0
Linux - 内存性能评估
ODOO12服务器性能评估与监控
load average这个输出值,这三个值的大小一般不能大于系统CPU的个数,例如,本输出中系统有4个CPU,如果load average的三个值长期大于4时,说明CPU很繁忙,负载很高,可能会影响系统性能,但是偶尔大于4时,倒不用担心,一般不会影响系统性能。相反,如果load average的输出值小于CPU的个数,则表示CPU还有空闲的时间片,比如本例中的输出,CPU是非常空闲的。
好派笔记
2021/09/13
1.2K0
Linux服务器性能评估与优化(一)--CPU和负载
性能调优是找出系统瓶颈并消除这些瓶颈的过程。 很多系统管理员认为性能调优仅仅是调整一下内核的参数即可解决问题, 事实上情况并不是这样。 性能调优是实现操作系统的各个子系统之间的平衡性,这些子系统包括:
黄规速
2022/04/14
5.5K0
Linux服务器性能评估与优化(一)--CPU和负载
LINUX下查看CPU使用率的命令
今天就来好好学习下Linux下如何查看CUP的使用率: 监控CPU的性能一般包括以下3点:运行队列、CPU使用率和上下文切换。 对于每一个CPU来说运行队列最好不要超过3,例如,如果是双核CPU就不要超过6。如果队列长期保持在3以上,说明任何一个进程运行时都不能马上得到cpu的响应,这时可能需要考虑升级cpu。另外满负荷运行cpu的使用率最好是user空间保持在65%~70%,system空间保持在30%,空闲保持在0%~5% 。
软测小生
2019/07/05
50.6K0
LINUX下查看CPU使用率的命令
五分钟带你掌握Linux系统查看CPU使用率、内存使用率、磁盘使用率
%us:表示用户空间程序的cpu使用率(没有通过nice调度) %sy:表示系统空间的cpu使用率,主要是内核程序。 %ni:表示用户空间且通过nice调度过的程序的cpu使用率。 %id:空闲cpu %wa:cpu运行时在等待io的时间 %hi:cpu处理硬中断的数量 %si:cpu处理软中断的数量 %st:被虚拟机偷走的cpu 注:99.0 id,表示空闲CPU,即CPU未使用率,100%-99.0%=1%,即系统的cpu使用率为1%。
不吃小白菜
2021/03/02
20.1K0
快速诊断Linux性能的10个命令
通过运行下面十个命令,你就能在六十秒内粗略地了解系统正在运行的进程及资源使用情况。通过查看这些命令输出的错误信息和资源饱和度(它们都很容易看懂),你可以接下来对资源进行优化。饱和是指某个资源的负载超出了其能够处理的限度,一旦出现饱和,它通常会在请求队列的长度或等待时间上暴露出来。
星哥玩云
2022/06/17
5200
Linux监控系统相关资源和运行状态命令整理
#前言:Linux系统自带了些实时查看监控系统运行状态的相关命令,接下来我们就来了解一下。
老油条IT记
2020/03/20
1.2K0
Linux下常用的监控工具和命令
如果性能测试的目标服务器是linux系统,在如何使用linux自带的命令来实现性能测试过程的监控分析呢?
苦叶子
2018/07/25
1.3K0
Linux下常用的监控工具和命令
linux 常用的性能分析命令vmstat|iostat|iotop|mpstat
1.vmstat--虚拟内存统计 vmstat(VirtualMeomoryStatistics,虚拟内存统计) 是Linux中监控内存的常用工具,可对操作系统的虚拟内存、进程、CPU等的整体情况进行监视。
瑾诺学长
2021/02/25
1.6K0
如何查看Linux系统的CPU使用率?
top 命令是一个动态查看系统进程和资源使用情况的工具。它可以显示系统的整体资源使用情况,包括CPU使用率。
用户11163528
2025/03/05
4.1K0
性能测试 操作系统性能分析思路总结
先查看系统整体负载(可通过w,uptime,top等命令查看),可以查看15分钟前,5分钟前,1分钟前到现在负载均值。
授客
2019/09/11
1.6K0
Linux性能检测常用的9个基本命令
作为一个Linux运维人员,主要就是对Linux服务器的性能做一些优化,本篇博文仅仅介绍如何性能检测常用的指令!
网络技术联盟站
2020/05/14
2K0
网工人必须掌握的Linux命令
作为一个Linux运维人员,主要就是对Linux服务器的性能做一些优化,本篇博文仅仅介绍如何性能检测常用的指令!
网络技术联盟站
2021/02/22
1.1K0
Java后端线上问题排查常用命令收藏
swap space 是磁盘上的一块区域,当系统物理内存吃紧时,Linux 会将内存中不常访问的数据保存到 swap 上,这样系统就有更多的物理内存为各个进程服务,而当系统需要访问 swap 上存储的内容时,再将 swap 上的数据加载到内存中,这就是常说的换出和换入。交换空间可以在一定程度上缓解内存不足的情况,但是它需要读写磁盘数据,所以性能不是很高。
好好学java
2021/03/29
1K0
Java后端线上问题排查常用命令收藏
Linux系统下的性能分析命令
在 Linux 系统下,有许多用于性能分析和调试的命令和工具,可以帮助您识别系统瓶颈、优化性能以及调查问题。本文将介绍在性能分析过程中,可能使用到的一些命令。
xcbeyond
2023/09/06
6030
Linux系统下的性能分析命令
Linux性能回溯工具-sysstat、atop、oswatch、nmon
在企业应用中,除了经常会用到企业级的性能监控和告警工具(如nagios、zabbix、Prometheus),还会在服务器设备出现性能问题时,可以通过部署一些可以进行性能回溯和追踪的性能分析工具,便于在主机hang死或挂机时,定位主机各项指标是否过载,也可以定位到具体是哪些程序引发了性能瓶颈。
start.zhou
2020/11/18
4.1K0
Linux性能回溯工具-sysstat、atop、oswatch、nmon
005.系统管理监测命令
CPU性能评估 vmstat命令 作用:可以对操作系统的内存信息、进程状态、CPU活动等进行监控。 语法:vmstat(选项)(参数) 选项 -a:显示活动内页; -f:显示启动后创建的进程总数; -m:显示slab信息; -n:头信息仅显示一次; -s:以表格方式显示事件计数器和内存状态; -d:报告磁盘状态; -p:显示指定的硬盘分区状态; -S:输出信息的单位。 参数 事件间隔:状态信息刷新的时间间隔; 次数:显示报告的次数。 举例 [root@study ~]# vmstat 3
木二
2021/11/15
7900
005.系统管理监测命令
【JVM进阶之路】八:性能监控工具-命令行篇
在实际的故障排查、性能监控中,常常是操作系统的工具和Java虚拟机的工具结合使用。
三分恶
2021/04/09
1.2K0
【JVM进阶之路】八:性能监控工具-命令行篇
四款常用服务器IO测试工具详细分析
top是一个常用的性能监控工具,可以用来实时查看系统资源的使用情况,包括CPU、内存、进程等信息,是Linux系统中常用的一种命令行工具。通过top可以查看系统当前的状态,并且可以对各种系统资源进行监控和管理。
IT运维技术圈
2023/09/07
9130
四款常用服务器IO测试工具详细分析
​Linux CPU 性能优化指南
本文作者:allenxguo,腾讯 QQ 音乐后台开发工程师 本文主要帮助理解 CPU 相关的性能指标,常见的 CPU 性能问题以及解决方案梳理。 系统平均负载 简介 系统平均负载:是处于可运行或不可中断状态的平均进程数。 可运行进程:使用 CPU 或等待使用 CPU 的进程 不可中断状态进程:正在等待某些 IO 访问,一般是和硬件交互,不可被打断(不可被打断的原因是为了保护系统数据一致,防止数据读取错误) 查看系统平均负载 首先top命令查看进程运行状态,如下: PID USER
腾讯技术工程官方号
2020/08/11
9K0
相关推荐
Linux - 内存性能评估
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档