Linux 1:平均负载

uptime命令

通过uptime可以了解到系统的负载情况,在命令行中输入uptime时,会输出以下信息:

root@iZ2ze6fssrhq5nqms7h4amZ:~# uptime
16:50:59 up 43 days, 20:22,  1 user,  load average: 0.11, 0.04, 0.01

其中

  • 16:50:59为当前时间
  • up 43 days,20:22为系统运行了43天20小时22秒
  • 1 user为当前共有一个用户登录
  • load average为过去1分钟、5分钟、15分钟的平均负载

如何理解平均负载

Linux的正统解释(man uptime)

现在只着重看一下uptime命令中关于平均负载的解释

System load averages is the average number of processes that are either in a runnable or uninterruptable state. A process in a runnable state is either using the CPU or waiting to use the CPU. A process in uninterruptable state is waiting for some I/O access, eg waiting for disk. The averages are taken over the three time intervals. Load averages are not normalized for the number of CPUs in a system, so a load average of 1 means a single CPU system is loaded all the time while on a 4 CPU system it means it was idle 75% of the time.

平均负载是三个时间间隔内处于可运行或不可中断状态进程的平均数。

  • 处于可运行状态的进程正在使用CPU或等待使用CPU。
  • 处于不可中断状态的进程正在等待某些I/O访问(如等待磁盘)。

负载平均值不是系统中CPU数量的标准化值。当负载平均值为1时,在单个CPU上表示系统一直处于负载状态,而在4 CPU系统上则表示75%的时间处于空闲状态。因此可以推断CPU的空闲状态可以表示为(N - M)/ N,其中N为CPU数量,M为平均负载值。

举个例子,当平均负载为2时,在不同CPU个数情况下有不同的含义:

  • 在2 个 CPU 的系统上,意味着所有的 CPU 都刚好被完全占用。
  • 在4 个 CPU 的系统上,意味着 CPU 有 50% 的空闲。
  • 在1 个 CPU 的系统中,意味着有一半的进程竞争不到 CPU。

平均负载多少合适

最理想的情况是平均负载等于CPU的个数

获取CPU个数的方式
$ cat /proc/cpuinfo| grep "physical id"| sort| uniq| wc -l

通过uptime命令可以获取到3个时间点的系统平均负载,要根据这三个时间点的平均负载来分析系统负载趋势

  • 如果 1 分钟、5 分钟、15 分钟的三个值基本相同,或者相差不大,那就说明系统负载很平稳。
  • 如果 1 分钟的值远小于 15 分钟的值,就说明系统最近 1 分钟的负载在减少,而过去 15 分钟内却有很大的负载。
  • 如果 1 分钟的值远大于 15 分钟的值,就说明最近 1 分钟的负载在增加,这种增加有可能只是临时性的,也有可能还会持续增加下去,所以就需要持续观察。一旦 1 分钟的平均负载接近或超过了 CPU 的个数,就意味着系统正在发生过载的问题。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值