<返回更多

如何分析系统的负载?生产排错必备技能

2023-09-03  微信公众号  猿java
加入收藏
作为一名后端程序员,应该能经常听到“系统负载过高”,“CPU打爆了”诸如此类的描述,那么,什么是系统负载过高?什么是 CPU打爆了?生产环境,又该如何排查?今天我们就来聊一聊。
遇到问题时,最重要的一环就是查看问题,下面分析 4个生产环境中会高频使用的查询指令。

一、如何查看负载 

 

top 命令

top是使用最高频的指令之一,命令及运行截图如下:

# 系统默认安装的命令top

 

通过执行指令可以看出:top 是交互式的系统监视工具,实时显示的信息特别多,主要包括下面几类:

  1. 进程信息:

    • PID:进程id,唯一标识进程

    • 用户:运行进程的用户

    • CPU 使用率:进程正在使用的 CPU 资源的百分比

    • 内存使用率:进程正在使用的内存的百分比

    • 进程状态:进程的状态,如运行、休眠、停止等

    • 进程优先级:进程的优先级

    • 进程启动时间:进程启动的时间

  2. 系统总体性能:

    • 系统平均负载:1分钟、5分钟和15分钟的平均负载,用于表示系统的负载情况

    • 总体 CPU使用率:系统的总体 CPU 使用率

    • 总体内存使用:系统的总体内存使用情况,包括总内存、空闲内存、已使用内存等信息

    • 总体交换分区使用:如果有交换分区,它的使用情况也会显示

  3. CPU 利用率:

    • 按核心或逻辑处理器显示每个 CPU 核心的使用情况,包括用户态、系统态、空闲时间等

  4. 内存和交换分区使用情况:

    • 物理内存:总物理内存、已使用内存、可用内存、缓存和缓冲区等信息

    • 交换分区:总交换空间、已使用交换空间和可用交换空间

  5. 任务信息:

    • 运行中的任务总数、运行任务数、睡眠任务数等

  6. 系统时间:

    • 当前系统时间以及系统运行时间

uptime 命令

top命令显示的信息太多,如果想简单的展示系统负载,uptime是比较匹配的命令,命令及运行截图如下:

# 系统默认安装的命令uptime

 

 

通过截图可以看出:uptime 命令只会显示系统的平均负载以及系统当前时间、已运行时间和登录用户数量 4个信息。

htop 命令

htop命令,系统默认是不安装的,所以在使用该命令时需要先安装,命令和运行截图如下:

​​​​​​​# 系统默认不安装,需要自己安装,比如:apt-get install htophtop

 

通过执行指令可以看出:htop 和 top很类似,也是交互式的系统监视工具,主要会显示下面8种信息:

w 命令

w 命令和 uptime很类似,命令及运行截图如下:

​​​​​​​# 系统默认安装w

 

通过执行指令可以看出:w 命令会显示当前登录用户的信息,包括平均负载。

通过执行上面 4个指令,我们可以看出:每个指令的结果里面都包含“load averages:  

数字1 数字2 数字3”, 那么 load averages是什么?后面的3个数字又代表什么含义?


 

二、平均负载

定义

load averages,中文翻译为:平均负载,它是指在一段时间内系统上运行的进程数量或等待资源的平均情况。通常用于 Unix 和类 Unix 系统。

定义看起来有些晦涩,其实,我们可以把平均负载简单理解成平均活跃进程数。

三个重要数字

介绍了平均负载的定义,接着分析 load averages 后面三个重要数字的含义,通过执行 man uptime指令,我们可以查看官方文档:

​​​​​​​# 系统默认安装的命令man uptime

 

 

从文档截图可以总结三个数字的含义分别为:

解释完 load averages 3个数字的含义,另一个问题也就随之而来:3个数字的值为多少代表系统健康?多少代表系统过载了?在解答这个问题之前,我们先来分析“CPU打爆了”。

三、CPU打爆了

CPU打爆了,其实就是说 CPU的使用率大于等于100%,比如,如果服务器只有一个 CPU,100% 就代表 CPU满负载,如果服务器有 2个 CPU,那么 CPU的使用率 >= 200%,CPU就被打爆了, 在生产环境,通常会把CPU总量的 80%~85%设置为报警阈值,这样就能提醒相关人员服务器的 CPU使用过高,需要特别关注。

那么,如何查看服务器的 CPU个数呢?可以使用下面的指令:

​​​​​​​# linux 查看CPU个数grep 'model name' /proc/cpuinfo | wc -l# mac 查看CPU个数sysctl -n hw.physicalcpu

 

如下图:

四、两者关系

分析了平均负载和 CPU使用率,那么两者之间存在什么关系呢?

在平均负载定义时提到平均负载就是进程平均数,因此,先来看看进程是什么:

进程是指计算机上运行的程序实例,通常包含 CPU密集型进程 和 IO密集型进程,两种进程的详情如下:

  1. CPU密集型进程:

  1. IO密集型进程:

到此,我们可以给平均负载重新定义,它是指系统中 IO密集型进程和 CPU密集型进程的平均数。这样是不是对平均负载有更好的理解。

而 CPU作为中央处理单元,它是执行系统中各种进程的硬件。假如每个 CPU上刚好有且只有一个进程在运行,是不是意味着不用切换 CPU,每个进程享受着 CPU 1对1的服务。因此,如果平均负载等于 CPU个数,就刚好满足了这种 1对1服务,所以,平均负载最理想的情况就是等于 CPU个数。

有了这个前提,可以得出:在单 CPU服务器上 load averages 1 1 1 是最理想的平均负载,同理,在 N个 CPU的服务器上 load averages N N N 是最理想的平均负载。

如果 平均负载的3个数字不等于 CPU个数,就代表负载不正常吗?下面我们分析一个案例:单 CPU服务器 load averages 0.6 1.2 0.8。

1分钟平均负载为0.6, 小于1, 属于低负载,5分钟平均负载为1.2,大于1,系统过载,15分钟平均负载为0.8, 也是低负载。平均负载对整体走势是: 从 15分钟的0.8 升高到 5分钟的 1.2, 因此系统服务在升高,但又从 5分钟的1.2 降到 1分钟的0.6, 说明服务器的负载在降低,最后正常,所以对于 load averages,我们应该按照整个发展趋势来分析,这样才能更好的分析系统的负载变化。趋势可以参考下面对手绘图:

那么,生产环境,平均负载多少是合理的?

业内经验值:小于 CPU总数的 70% 是正常的,超过 70% 就需特别注意。但这个值并不是绝对的,需要根据具体业务具体分析。

最后,平均负载高,CPU就一定高吗?

在讲解进程时提到进程有 CPU密集型和 IO密集型,而 IO密集型对 CPU的影响不大,所以,平均负载高,CPU不一定高。

因此,在生产排查时,如果发现负载高,CPU使用率高,那任务是 CPU密集型概率比较大;如果发现负载高,CPU使用率不是很高,那任务是 IO密集型概率比较大。


 

五、CPU飙高排查过程

CPU飙高排查,应该是对很多后端程序员的一个能力要求,下面给出了一个常用的排查步骤:

  1. 连接到问题服务器;

  2. 执行 top命令:查找 CPU使用最高的进程PID;

  3. 执行 jstack > t.log 命令:导出线程堆栈;

  4. 执行 top -pH pid:查看进程所有线程的 CPU使用率以及线程Id;

  5. 执行 printf %x 线程pid:将线程ID转换成16进制ID,并在步骤3中生成的线程堆栈里找到对应的线程;

  6. 根据堆栈信息,找到对应源码分析具体原因;

六、总结

关键词:负载      点击(3)
声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多负载相关>>>