Linux性能优化实践——平均负载

平均负载是指系统中处于可运行和不可中断状态的平均进程数,包括CPU密集型和I/O密集型进程。理想情况下,平均负载应接近CPU个数。当平均负载高于CPU数量的70%,可能需要检查高负载原因,因为过高的负载可能导致进程响应变慢。CPU使用率和平均负载并不完全对应,I/O等待也可能增加平均负载。
摘要由CSDN通过智能技术生成

平均负载(Load Average)

当我们输入uptime命令时,
在这里插入图片描述
这里有几个参数,解释如下

  • 0:54 :当前时间;
  • up 50 mins:系统运行时间;
  • 2 users:正在登录用户数;
  • load averages: 2.12 1.85 1.81:平均负载;

这里平均负载是什么含义?
平均负载是指单位时间内,系统处于可运行状态不可中断状态的平均进程数,也就是平均活跃进程数

输入命令ps aux,可以看到进程的PID,CPU使用率,以及进程状态等等信息,
在这里插入图片描述

  • 可运行的进程:指正在使用CPU或者正在等待CPU的进程,即上面STAT为R(Running/Runnable)状态的进程;
  • 不可中断状态的进程:正处于内核态关键流程中的进程,并且这些流程是不可打断的,比如最常见的是等待硬件设备的I/O响应,也就是STAT为D(Uninterruptible Sleep,也称为Disk Sleep)状态的进程;

平均负载多少合理

平均负载最理想的情况是等于CPU个数。
先查看系统有几个CPU,Linux系统可以通过top命令或文件/proc/cpuinfo中获取CPU个数,
本机输入下列命令查看基本信息:

  • sysctl hw.physicalcpu:查看物理CPU个数;
  • sysctl hw.logicalcpu:查看逻辑CPU个数;
  • system_profiler SPHardwareDataType:查看硬件信息总揽;
    在这里插入图片描述
    可以看出平均负载接近理想,三个数值是在三个不同时间间隔(1分钟总、5分钟、15分钟)的平均值。从数值上看系统负载较平稳。

使用top命令也可以查看平均负载的值,如下,
在这里插入图片描述
当平均负载高于CPU数量70%的时候,就需要排查负载高的问题了。一旦负载过高,可能导致进程响应变慢,进而影响服务的正常功能。

平均负载与CPU使用率

它不仅包括了正在使用CPU的进程,还包括等待CPU和等待I/O的进程。
CPU使用率是单位时间内CPU繁忙情况的统计,和平均负载不一定完全对应,

  • CPU密集型进程:使用大量CPU会导致平均负载升高,两者一致;
  • I/O密集型进程:等待I/O也会导致平均负载升高,但CPU使用率不一定高;
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值