Linux如何查看系统负载

Linux如何查看系统负载

操作系统的负载状态,反映了应用程序的资源使用情况,从中能找出应用程序优化的瓶颈所在。

系统平均负载,是指处于运行或不可打扰状态的进程的平均数。

处于运行,表示运行态,占用 CPU,或就绪态,等待 CPU 调度。

不可打扰,表示阻塞,正在等待 I/O

推荐:【linux视频教程】

在 Linux 系统中,要查看负载情况一般使用 uptime 命令(w 命令和 top 命令也行)*

一、uptime 命令

$ uptime16:33:56 up 69 days,  5:10,  1 user,  load average: 0.14, 0.24, 0.29

以上信息的解析如下:

16:33:56 : 当前时间

up 69 days, 5:10 : 系统运行了 69 天 5 小时 10 分

1 user : 当前有 1 个用户登录了系统 load average: 0.14, 0.24, 0.29 : 系统在过去 1 分钟内,5 分钟内,15 分钟内的平均负载

load average: 0.14, 0.24, 0.29 : 系统在过去 1 分钟内,5 分钟内,15 分钟内的平均负载

平均负载解析

查看逻辑 CPU 核心数:

$ grep 'model name' /proc/cpuinfo | wc -l1

运行结果表示,有 1 个逻辑 CPU 核心。以 1 个 CPU 核心为例,假设 CPU 每分钟最多处理 100 个进程 –

load=0,没有进程需要 CPU

load=0.5,CPU 处理了 50 个进程

load=1, CPU 处理了 100 个进程,这时 CPU 已被占满,但系统还是能顺畅运作的

load=1.5, CPU 处理了 100 个进程,还有 50 个进程正在排除等着 CPU 处理,这时,CPU 已经超负荷工作了

为了系统顺畅运行,load 值最好不要超过 1.0,这样就没有进程需要等待了,所有进程都能第一时间得到处理。

很显然,1.0 是一个关键值,超过这个值,系统就不在最佳状态了。 一般 0.7 是一个比较理想的值。

另外,load 值的健康状态还跟系统 CPU 核心数相关,如果 CPU 核心数为 2,那么 load 值健康值应该为 2,以此类推。

评价系统的负载一般采用 15 分钟内的那个平均负载值。

二、w 命令

$ w 17:47:40 up 69 days,  6:24,  1 user,  load average: 0.46, 0.26, 0.25USER     TTY      FROM              LOGIN@   IDLE   JCPU   PCPU WHATlvinkim  pts/0    14.18.144.2      15:55    0.00s  0.02s  0.00s w

第 1 行:与 uptime 一相同。

第 2 行以下,当前登录用户的列表。

三、top 命令

$ toptop - 17:51:23 up 69 days,  6:28,  1 user,  load average: 0.31, 0.30, 0.26Tasks:  99 total,   1 running,  98 sleeping,   0 stopped,   0 zombieCpu(s):  2.3%us,  0.2%sy,  0.0%ni, 97.4%id,  0.0%wa,  0.0%hi,  0.0%si,  0.0%stMem:   1922244k total,  1737480k used,   184764k free,   208576k buffersSwap:        0k total,        0k used,        0k free,   466732k cached\  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                    1 root      20   0 19232 1004  708 S  0.0  0.1   0:01.17 init                                                                        2 root      20   0     0    0    0 S  0.0  0.0   0:00.01 kthreadd                                                                ...

第 1 行:与 uptime 一相同。

第 2 行:进程数信息。

Tasks: 99 total : 总共有 99 个进程

1 running : 1 个进程正在占用 CPU

98 sleeping : 98 个睡眠进程

0 stopped : 0 个停止的进程

0 zombie : 0 个僵尸进程

第 3 行 : CPU 使用率

us (user): 非 nice 用户进程占用 CPU 的比率

sy (system): 内核、内核进程占用 CPU 的比率

ni (nice): 用户进程空间内改变过优先级的进程占用 CPU 比率

id (idle): CPU 空闲比率,如果系统缓慢而这个值很高,说明系统慢的原因不是 CPU 负载高

wa (iowait): CPU 等待执行 I/O 操作的时间比率,该指标可以用来排查磁盘 I/O 的问题,通常结合 wa 和 id 判断

hi (Hardware IRQ): CPU 处理硬件中断所占时间的比率

si (Software Interrupts): CPU 处理软件中断所占时间的比率

st (steal): 流逝的时间,虚拟机中的其他任务所占 CPU 时间的比率

需要注意的一些情形:

用户进程 us 占比高,I/O 操作 wa 低:说明系统缓慢的原因在于进程占用大量 CPU,通常还会伴有教低的空闲比率 id,说明 CPU 空转时间很少。

I/O 操作 wa 低,空闲比率 id 高:可以排除 CPU 资源瓶颈的可能。

I/O 操作 wa 高:说明 I/O 占用了大量的 CPU 时间,需要检查交换空间的使用,交换空间位于磁盘上,性能远低于内存,当内存耗尽开始使用交换空间时,将会给性能带来严重影响,所以对于性能要求较高的服务器,一般建议关闭交换空间。另一方面,如果内存充足,但 wa 很高,说明需要检查哪个进程占用了大量的 I/O 资源。

更多负载情形,可在实际中灵活判断。

四、iostat 命令

iostat 命令可以查看系统分区的 IO 使用情况

$ iostat Linux 2.6.32-573.22.1.el6.x86_64 (sgs02)   01/20/2017     _x86_64_   (1 CPU)\avg-cpu:  %user   %nice %system %iowait  %steal   %idle           2.29    0.00    0.25    0.04    0.00   97.41\Device:            tps   Blk_read/s   Blk_wrtn/s   Blk_read   Blk_wrtnvda               1.15         3.48        21.88   21016084  131997520

一些值得注意的 IO 指标 :

Device : 磁盘名称

tps : 每秒 I/O 传输请求量

Blk_read/s : 每秒读取多少块,查看块大小可参考命令 tune2fs

Blk_wrtn/s : 每秒写取多少块

Blk_read : 一共读了多少块

–Blk_wrtn : 一共写了多少块

五、iotop 命令

iotop 命令类似于 top 命令,但是显示的是各个进程的 I/O 情况,对于定位 I/O 操作较重的进程有比较大的作用。

# iotopTotal DISK READ: 0.00 B/s | Total DISK WRITE: 774.52 K/s  TID  PRIO  USER     DISK READ  DISK WRITE  SWAPIN     IO>    COMMAND                                                                  272 be/3 root        0.00 B/s    0.00 B/s  0.00 %  4.86 % [jbd2/vda1-8] 9072 be/4 mysql       0.00 B/s  268.71 K/s  0.00 %  0.00 % mysqld 5058 be/4 lvinkim     0.00 B/s    3.95 K/s  0.00 %  0.00 % php-fpm: pool www    1 be/4 root        0.00 B/s    0.00 B/s  0.00 %  0.00 % init

可以看到不同任务的读写强度。

六、sysstat 工具

很多时候当检测到或者知道历史的高负载状况时,可能需要回放历史监控数据,这时 sar 命令就派上用场了,sar 命令同样来自 sysstat 工具包,可以记录系统的 CPU 负载、I/O 状况和内存使用记录,便于历史数据的回放。

sysstat 的配置文件在 /etc/sysconfig/sysstat 文件,历史日志的存放位置为 /var/log/sa

统计信息都是每 10 分钟记录一次,每天的 23:59 会分割统计文件,这些操作的频率都在 /etc/cron.d/sysstat 文件配置。

七、sar 命令

使用 sar 命令查看当天 CPU 使用:

$ sarLinux 2.6.32-431.23.3.el6.x86_64 (szs01)   01/20/2017     _x86_64_   (1 CPU)\10:50:01 AM     CPU     %user     %nice   %system   %iowait    %steal     %idle11:00:01 AM     all      0.45      0.00      0.22      0.40      0.00     98.93Average:        all      0.45      0.00      0.22      0.40      0.00     98.93

使用 sar 命令查看当天内存使用:

$ sar -rLinux 2.6.32-431.23.3.el6.x86_64 (szs01)   01/20/2017     _x86_64_   (1 CPU)\10:50:01 AM kbmemfree kbmemused  %memused kbbuffers  kbcached  kbcommit   %commit11:00:01 AM     41292    459180     91.75     44072    164620    822392    164.32Average:        41292    459180     91.75     44072    164620    822392    164.32

使用 sar 命令查看当天 IO 统计记录:

$ sar -bLinux 2.6.32-431.23.3.el6.x86_64 (szs01)   01/20/2017     _x86_64_   (1 CPU)\10:50:01 AM       tps      rtps      wtps   bread/s   bwrtn/s11:00:01 AM      3.31      2.14      1.17     37.18     16.84Average:         3.31      2.14      1.17     37.18     16.84

更多 sar 用法,请 man sar 。

以上就是Linux如何查看系统负载的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/169596.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月1日 01:40:11
下一篇 2025年11月1日 01:44:10

相关推荐

  • C++初学者如何编写小游戏贪吃蛇

    贪吃蛇游戏能帮助C++初学者掌握基础概念,通过拆解为初始化、循环逻辑和结束流程三个模块学习核心编程技能。首先用二维数组表示地图,结合vector存储蛇身坐标,实现移动与绘图;利用随机函数生成食物并检测碰撞;通过_kbhit()或跨平台库处理输入,控制方向避免反向冲突;使用Sleep()或std::t…

    2025年12月18日
    000
  • C++环境搭建中路径配置错误怎么排查

    路径配置错误主因是系统找不到编译器或库文件,需检查PATH环境变量是否包含工具链bin目录,并确保头文件和库文件路径正确配置。 C++环境搭建中遇到路径配置错误,说白了,就是你的系统找不到它需要用的那些工具,比如编译器( g++ 或 cl.exe )、链接器或者特定的库文件。最直接的排查思路,就是先…

    2025年12月18日
    000
  • C++如何配置多版本编译器共存环境

    C++多版本编译器共存需通过环境变量和构建系统协同管理。在Linux/macOS中,可利用PATH切换、update-alternatives或模块系统灵活选择GCC/Clang版本;Windows下则依赖Visual Studio的开发人员命令提示符、vswhere脚本或MSYS2包管理器实现MS…

    2025年12月18日
    000
  • C++如何选择适合的IDE进行环境搭建

    答案是根据%ignore_a_1%、项目类型和个人习惯选择最适合的C++ IDE。Windows下首选Visual Studio,macOS推荐Xcode或VS Code,Linux则适合VS Code或CLion;IDE功能全面但笨重,轻量编辑器灵活但需配置;环境搭建常见问题包括编译器路径错误、C…

    2025年12月18日
    000
  • C++使用VSCode和CMake搭建项目环境方法

    答案是:在VSCode中通过安装编译器、CMake及C++扩展,创建CMakeLists.txt配置项目,利用CMake Tools扩展实现构建与调试。 在VSCode里用CMake搭建C++项目环境,其实就是把VSCode作为你的代码编辑器和调试前端,而CMake则负责生成跨平台的构建系统。核心思…

    2025年12月18日
    000
  • C++虚函数表优化与多态性能分析

    虚函数表优化通过内联、静态绑定等手段减少运行时查表开销,提升多态调用性能。编译器在类型确定时可内联虚函数,final类和LTO进一步促进优化,CRTP等静态多态技术可替代虚函数以提高效率。 C++虚函数表优化旨在提升多态调用的性能。其核心在于减少虚函数调用的开销,通过内联、静态绑定等方式,尽可能避免…

    2025年12月18日
    000
  • C++文件读写权限如何设置

    在C++中,文件读写权限需通过操作系统机制设置,类Unix系统使用chmod()函数修改权限,需包含头文件并配合系统调用实现。 在C++中,文件读写权限的设置主要依赖于操作系统提供的机制,尤其是类Unix系统(如Linux、macOS)中的文件权限模型。Windows系统也有类似的权限控制,但实现方…

    2025年12月18日
    000
  • C++循环优化与算法选择技巧

    C++性能优化需优先选择高效算法和数据结构,再结合循环不变式外提、数据局部性优化、分支预测提示及SIMD向量化等技巧,通过Profiler和std::chrono定位瓶颈,避免过早优化,在可维护性与性能间取得平衡。 C++的性能优化,特别是涉及到循环和算法选择,其实是一门艺术,更像是一种对系统底层运…

    2025年12月18日
    000
  • C++在Windows子系统WSL中搭建环境方法

    在WSL中搭建C++环境需先启用WSL并安装Linux发行版,更新系统后安装build-essential、clang、cmake等开发工具,再通过VS Code的Remote – WSL扩展实现高效编辑与调试,配合tasks.json和launch.json配置编译调试任务,利用WSL…

    2025年12月18日
    000
  • C++如何实现简单的贪吃蛇游戏

    C++实现贪吃蛇的核心在于控制台I/O、非阻塞输入、定时更新与状态管理,使用vector维护蛇身,通过头插尾删实现移动与增长,结合SFML或SDL可升级为图形化游戏。 用C++实现一个简单的贪吃蛇游戏,其实比很多人想象的要直接,它主要依赖于控制台的字符输出和基本的逻辑判断。核心思路是维护一个表示蛇身…

    2025年12月18日
    000
  • C++内存模型对多线程程序性能影响

    C++内存模型通过定义多线程下内存操作的可见性与顺序,直接影响程序正确性和性能。它基于先行发生关系、数据竞争、可见性与排序等核心概念,确保共享数据的一致性并避免未定义行为。为平衡性能与正确性,应优先使用std::atomic配合合适的内存序:relaxed用于无顺序需求的原子操作,acquire/r…

    2025年12月18日
    000
  • C++在Clion中环境搭建详细教程

    C++在CLion中的环境搭建,说白了,就是确保你的电脑上有一套能编译C++代码的工具链,然后告诉CLion这些工具在哪里。这听起来可能有点绕,但实际上,核心就是“编译器在哪儿?调试器在哪儿?项目构建工具CMake在哪儿?”把这三位爷伺候好了,CLion自然就能开心地工作了。 解决方案 搭建C++环…

    2025年12月18日
    000
  • C++如何在Docker容器中搭建开发环境

    答案:通过Dockerfile构建包含编译器、调试器等工具的C++开发镜像,利用容器挂载本地代码实现隔离且一致的开发环境,提升可重复性与团队协作效率。 在Docker容器中搭建C++开发环境,核心思路是构建一个包含所有必要工具链(编译器、调试器、构建系统等)的隔离镜像,然后基于此镜像运行容器,将本地…

    2025年12月18日
    000
  • C++内存管理与多线程同步问题

    C++内存管理应优先使用智能指针(如std::unique_ptr、std::shared_ptr)实现RAII自动释放,避免裸指针和手动new/delete导致的泄漏;多线程同步需根据场景选择互斥锁、条件变量或原子操作,并通过统一锁序、使用std::lock等手段防止死锁,确保资源安全访问。 C+…

    2025年12月18日
    000
  • C++如何使用ofstream写入Unicode文本

    答案是使用UTF-8编码配合ofstream写入Unicode文本需确保字符串为UTF-8格式并可添加BOM,或使用wofstream处理宽字符编码。具体做法包括:1. 用std::ofstream以二进制模式打开文件,先写入UTF-8 BOM(xEFxBBxBF),再写入UTF-8编码的字符串;2…

    2025年12月18日
    000
  • C++在Linux系统中环境搭建方法

    首先安装GCC/G++和GDB,再根据项目需求安装相应库,最后通过编译运行测试程序验证环境。 C++在Linux系统中的环境搭建,简单来说,就是安装编译器、调试器,以及必要的库文件。就像盖房子,编译器是砖瓦匠,调试器是验房师,库文件则是各种建材。 首先,我们需要安装GCC/G++编译器。这是C++编…

    2025年12月18日
    000
  • C++运行第一个程序需要准备哪些环境

    核心准备是编译器和开发工具:编译器将C++代码翻译成机器码,如GCC、Clang或MSVC;开发工具包括文本编辑器(如VS Code)或IDE(如Visual Studio),用于编写和调试代码。搭建环境即配置编译器与工具链,使代码能被正确编译、链接并运行,最终生成可执行文件。 要让你的C++程序跑…

    2025年12月18日
    000
  • C++在不同操作系统下如何统一环境

    使用CMake、包管理器(Conan/vcpkg)、Docker和跨平台库是实现C++跨平台开发统一环境的核心方案。首先,CMake作为元构建系统,通过生成各平台原生构建文件实现构建流程统一;配合外部构建和模块化CMakeLists.txt可提升项目可维护性。其次,Conan或vcpkg解决依赖管理…

    2025年12月18日
    000
  • C++如何配置头文件和库文件路径

    配置C++头文件和库文件路径需设置include和library路径,确保编译器找到头文件、链接器找到库文件,可通过IDE、Makefile或CMake配置,并根据需求选择静态库或动态库。 C++配置头文件和库文件路径,简单来说,就是告诉编译器和链接器去哪里找到你需要的“工具”(头文件和库文件)。配…

    2025年12月18日
    000
  • C++使用VSCode进行环境配置的步骤

    答案:配置VSCode的C++环境需安装VSCode、选择编译器(如MinGW-w64、MSVC或Clang)、安装C/C++扩展,并配置tasks.json和launch.json文件。具体步骤包括:下载安装VSCode;根据操作系统选择并安装对应编译器,Windows推荐MinGW-w64或MS…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信