理解 Linux 的平均负载和性能监控
来源:互联网 发布:sql union with ur 编辑:程序博客网 时间:2024/06/06 01:17
在本文中,我们将解释 Linux 系统中最关键的管理任务之一——关于系统 / CPU 的负载和平均负载的性能监控。
首先来看所有的类 UNIX 系统中两个重要的表述:
- 系统负载 / CPU 负载 – 衡量 Linux 系统的 CPU 过载或利用率低的指标,即处于运算状态或等待状态的 CPU 核心数。
- 平均负载 – 通过固定的时间周期如 1、5、15 分钟计算出的平均的系统负载。
Linux 中,平均负载一般指在内核运行队列中被标记为运行或不可打断状态的进程的平均数。
注意:
- 几乎没有 Linux 或类 Unix 系统不为用户展示平均负载的值。
- 完全空闲的 Linux 系统平均负载为 0,不包括空闲进程。
- 绝大多数类 Unix 系统只统计运行和等待状态的进程。但是在 Linux 中,平均负载也包括处于不可打断的睡眠状态的进程——它们是在等待其它系统资源如磁盘 I/O 等的进程。
如何监测 Linux 系统平均负载
有诸多方式监测系统平均负载,如 uptime
,它会展示系统运行时间、用户数量及平均负载:
$ uptime07:13:53 up 8 days, 19 min, 1 user, load average: 1.98, 2.15, 2.21
平均负载的数字从左到右的含义依次为:
- 最近 1 分钟的平均负载为 1.98
- 最近 5 分钟的平均负载为 2.15
- 最近 15 分钟的平均负载为 2.21
高平均负载意味着系统是过载的:许多进程在等待 CPU 时间。
理解系统平均负载和 CPU 核心数的关系
考虑了 CPU 核心数的影响,才能解释系统负载。
多处理器 Vs 多核处理器
- 多处理器 – 一个计算机系统中集成两个或多个物理 CPU
- 多核处理器 – 单个物理 CPU 有两个或多个单独的核并行工作(也叫处理单元)。双核意味着有两个处理单元,4 核有 4 个处理单元,以此类推。
此外,Intel 引入了超线程技术用来提高并行计算能力。
通过超线程技术,在操作系统中,单个物理 CPU 表现的和两个逻辑 CPU 一样。(实际在硬件上只有一个 CPU)。
注意,单个 CPU 核同一时间只能执行一个任务,于是产生了多 CPU/处理器、多核 CPU,以及多线程技术。
多 CPU 时,多个程序可以同时执行。如今的 Intel CPU 使用了多核心和超线程技术。
可以使用 nproc 或 lscpu 命令查看系统中的处理器单元数量。
$ nproc4# 或者lscpu为了进一步理解系统负载,需要做一些假设。假设系统负载如下:
23:16:49 up 10:49, 5 user, load average: 1.00, 0.40, 3.35
在单核系统中意味着:
- CPU 被充分利用(100%);最近的 1 分钟有 1 个进程在运行。
- CPU 有 60% 处于空闲状态;在最近的 5 分钟没有进程等待 CPU 时间。
- CPU 平均过载了 235%;最近的 15 分钟平均有 2.35 个进程在等待 CPU 时间。
在双核系统中意味着:
- 有一个 CPU 处于完全空闲状态,另一个 CPU 被使用;最近的 1 分钟没有进程等待 CPU 时间。
- CPU 平均 160% 处于空闲状态;最近的 5 分钟没有进程等待 CPU 时间。
- CPU 平均过载了 135%;最近的 15 分钟有 1.35 个进程等待 CPU 时间。
总而言之,如果你是系统管理员,你应该关注高的平均负载。平均负载高于 CPU 核心数意味着需要增加 CPU,反之则意味着 CPU 未被充分利用。
阅读全文
0 0
- 理解 Linux 的平均负载和性能监控
- [linux服务器] 监控系统的平均负载
- 【转贴】[linux服务器] 监控系统的平均负载
- 监控入门-Linux的平均负载(load average)
- 监控入门-Linux的平均负载(load average)
- 理解Linux和其他UNIX-Like系统上的平均负载
- Linux系统的平均负载
- linux系统的平均负载
- linux系统的平均负载
- Linux系统的平均负载
- Linux系统的平均负载
- linux下查看系统资源和负载,以及性能监控
- linux下查看系统资源和负载,以及性能监控
- linux下查看系统资源和负载,以及性能监控
- linux 下查看系统资源和负载,以及性能监控
- linux 下查看系统资源和负载,以及性能监控
- linux下查看系统资源和负载,以及性能监控
- linux 下查看系统资源和负载,以及性能监控
- 交叉编译工具-学习
- viewpager生成动态小圆点
- spark streaming job 耗时监控
- 模仿通讯录
- 导入导出Excel-JAVA
- 理解 Linux 的平均负载和性能监控
- 什么叫执行力!看完这个故事你做到了多少?
- DOS文件系统-FAT32的理解
- validationQuery是什么??
- eclipse 与 spring boot 版本地址
- Ansible问题总结
- 短信验证
- fmt标签的格式化日期使用
- Android MVP 架构