Linux

关注公众号 jb51net

关闭
首页 > 网站技巧 > 服务器 > Linux > Linux uptime查看系统负载

Linux通过uptime查看系统负载是否过高的方法

作者:A-刘晨阳

uptime 命令是Linux系统中一个非常基础且重要的工具,它主要用于获取主机的运行时间和查询系统的负载情况,通过这个命令,用户可以快速了解服务器的稳定性、当前活跃的用户数量以及系统的平均负载,所以本文给大家介绍了Linux通过uptime查看系统负载是否过高的方法

1. 什么是负载(load average)?

[root@k8s-node1 a]# uptime
 17:16:23 up 49 days, 6:35, 4 users, load average: 1.04, 1.37, 1.65

2. 快速判断负载是否过高公式

饱和度 = loadavg / 逻辑 CPU 核数

获取CPU核数(以下命令都可):

nproc               
grep -c ^processor /proc/cpuinfo
lscpu | grep -i cpu\(s\)\: | awk '{print $2}'

例如:

- cpu核数:32
- loadavg:6.21

# 计算(保留一位即可,第二位可四舍五入)
6.21/32=0.2
# 0.2,属于非常空闲的状态
饱和度区间经验含义建议
< 0.5空闲资源充足
0.5–0.7健康正常业务
0.7–1.0繁忙有排队,可接受
1.0–1.5重载需要观察
> 1.5过载立即排查

延迟敏感 服务(API、游戏)可把红线降到 0.7

3. 一条命令判断当前状态

#!/bin/bash
cores=$(nproc)
read one five fifteen < /proc/loadavg
sat1=$(awk -v c="$cores" -v l="$one"     'BEGIN{printf "%.0f%%",l/c*100}')
sat5=$(awk -v c="$cores" -v l="$five"    'BEGIN{printf "%.0f%%",l/c*100}')
sat15=$(awk -v c="$cores" -v l="$fifteen" 'BEGIN{printf "%.0f%%",l/c*100}')
printf "CPU饱和度:\n1 min\t5 min\t15 min\n%s\t%s\t%s\n" "$sat1" "$sat5" "$sat15"

别名可以根据自己的喜好去自定义,定义之前请确保不要和命令冲突;

alias load="sh /路径/load_check.sh"
vim ~/.bashrc
# 在最后一行追加
alias load="sh /路径/load_check.sh"

# 保存退出
# source使其生效
sorce ~/.bashrc
[root@localhost ~]# load
CPU饱和度:
1 min	5 min	15 min
1%	1%	2%

就可以很明显的看到负载的饱和度,再结合上面的饱和度表,来判断是否过载;

4. 场景举例

例 1:4 核机器 load=6
饱和度 = 6/4 = 150 %(1.5)过载,需进一步排查。
          ↑   ↑
         百分比 小数点

例 2:64 核机器 load=32
饱和度 = 32/64 = 50 %(0.5)健康,但需确认是否 IO 等待。

例 3:64 核机器 load=12
饱和度 = 12/64 = 18 %(0.18)空闲,不用管,资源很充足。

5. 如何肉眼来判断负载是否过高?

nproc

例:回显 32 心里就记住 ≈30 这条线。

load average: 6.21, 7.50, 9.00
               ↑     ↑      ↑
             1min  5min   15min

所以 6.21 远 < 16,秒判空闲

load 数字小于核数一半 → 空;
接近核数 → 满;
远超核数 → 爆。

6. 负载高 ≠ 问题定界,可以继续进行深挖排查是什么导致的

工具看啥
top / htop按 1 展开每核,观察 CPU 是否跑满
或者top P,查看哪个cpu占用最高。
iostat -x 1%util / await,确认 磁盘 IO 瓶颈
utils大于80磁盘io过高
await对SSD而言,1–2就很大了,但对机械盘大于10明显感觉卡
vmstat 1观察 r 列(运行队列)b 列(阻塞队列)
r正在运行 + 等待 CPU 的任务数(长期) > 核数 = cpu很堵
b处于不可中断睡眠(D 状态)的任务数 > 0 = 达到了磁盘/网络 IO 瓶颈

以上就是Linux通过uptime查看系统负载是否过高的方法的详细内容,更多关于Linux uptime查看系统负载的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文