美文网首页
理解系统平均负载

理解系统平均负载

作者: wayyyy | 来源:发表于2020-07-19 22:40 被阅读0次

    查看系统配置

    • 查看系统版本

      lsb_release -a
      
    • 查看内存

    • 查看CPU

      cat /proc/cpuinfo
      
    • 查看磁盘

    查看系统负载

    uptime
    image.png
    top
    top.jpg
    • 第一行显示的信息分别为:

      • 目前的时间
      • 开机到目前的时间
      • 已经登录的系统用户数
      • 系统在1,5,15分钟的平均工作负载
    • 第二行显示的信息:

      • 目前进程总数,以及各状态的进程数量
    • 第三行CPU的整体负载

      • %us
      • %sy
      • %ni
      • %id
      • %wa
      • %hi
      • %si
      • %st
    • 第四行物理内存使用量

    • 第五行虚拟内存使用量,交换分区

    • 在top执行过程中:可以输入以下命令:

      • P 按照CPU使用排序
      • M 按照内存资源使用排序
      • N 按照PID使用排序
    • top -d 5 界面更新的秒数

    • top -Hp [进程ID] 可以看某个进程的所有线程运行情况

    • top -b -n 2 > text 可以将结果写入文件

    • top -p [PID] 检测指定进程的资源占用

    怎么理解平均负载

    man uptime

    System load averages is the average number of processes that are either in a runnable or uninter‐
    ruptable 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 或者正在等待 CPU 的进程,也就是我们常用 ps 命令看到的,处于 R 状态(Running 或 Runnable)的进程。

    • 不可中断状态的进程 则是正处于内核态关键流程中的进程,并且这些流程是不可打断的,比如最常见的是等待硬件设备的 I/O 响应,也就是我们在 ps 命令中看到的 D 状态(Uninterruptible Sleep,也称为 Disk Sleep)的进程。比如,当一个进程向磁盘读写数据时,为了保证数据的一致性,在得到磁盘回复前,它是不能被其他进程或者中断打断的,这个时候的进程就处于不可中断状态。如果此时的进程被打断了,就容易出现磁盘数据与进程数据不一致的问题。

    • 平均负载多少合适
      平均负载最理想的情况是等于 CPU 个数。
      当平均负载高于 CPU 数量 70% 的时候,就应该分析排查负载高的问题了。一旦负载过高,就可能导致进程响应变慢,进而影响服务的正常功能。

    测试

    在理解了上面的例子后,我们分别测试不同场景下的性能

    CPU密集型

    第一个终端执行:stress --cpu 1 --timeout 600
    第二个终端执行:watch -d uptime
    第三个终端执行:mpstat -P ALL 5

    image.png

    那么到底时哪个进程导致了CPU的使用率为100%呢,可以使用pidstat -u 5 1来查询:

    image.png
    IO密集型

    第一个终端执行:stress -i 1 --timeout 600
    第二个终端执行:watch -d uptime
    第三个终端执行:mpstat -P ALL 5

    image.png

    那么到底时哪个进程导致了CPU的使用率为100%呢,可以使用pidstat -u 5 1来查询:

    大量进程

    第一个终端执行:stress -c 4 --timeout 600
    第二个终端执行:watch -d uptime


    参考资料

    1. https://time.geekbang.org/column/article/69618?utm_campaign=guanwang&utm_source=baidu-ad&utm_medium=ppzq-pc&utm_content=title&utm_term=baidu-ad-ppzq-title

    相关文章

      网友评论

          本文标题:理解系统平均负载

          本文链接:https://www.haomeiwen.com/subject/hlwrkktx.html