在Linux系统运行过程中,及时掌握CPU、内存、磁盘、网络等资源的占用情况,能够快速定位性能瓶颈,避免服务出现卡顿、崩溃等问题。Linux系统自带了多个轻量且功能强大的性能监控工具,无需额外安装依赖即可直接使用。

使用top命令实时监控进程资源
top是Linux中最常用的实时性能监控工具,能够动态展示系统中各个进程的资源占用情况,默认每隔3秒刷新一次数据。执行以下命令即可启动top监控:
# 直接执行top命令启动监控 top
top界面的核心指标含义如下:
- 第一行:系统运行时间、当前登录用户数、系统负载(1分钟、5分钟、15分钟的平均负载)
- 第二行:进程总数、运行中进程数、休眠进程数、停止进程数、僵尸进程数
- 第三行:CPU使用率,包括用户态占比、系统态占比、空闲占比等
- 第四行:内存总大小、已使用内存、空闲内存、缓冲内存
- 第五行:交换分区总大小、已使用交换分区、空闲交换分区
在top监控界面中,按下shift+p可以按CPU使用率排序进程,按下shift+m可以按内存使用率排序进程,按下q可以退出监控。
使用vmstat查看系统整体性能
vmstat可以统计系统的CPU、内存、磁盘、中断等整体运行数据,适合查看系统一段时间的性能趋势。基础用法如下:
# 每隔2秒输出一次统计结果,共输出5次 vmstat 2 5
输出结果的核心列含义如下:
| 列名 | 含义说明 |
|---|---|
| r | 等待运行的进程数,数值越大说明CPU越繁忙 |
| free | 空闲内存大小,单位是KB |
| si | 每秒从交换分区换入内存的大小 |
| so | 每秒从内存换出到交换分区的大小 |
| us | 用户态CPU使用率 |
| sy | 系统态CPU使用率 |
| id | CPU空闲率 |
使用iostat监控磁盘性能
iostat属于sysstat工具包,部分Linux发行版默认未安装,可通过包管理器安装:
# CentOS/RHEL系统安装 yum install sysstat -y # Ubuntu/Debian系统安装 apt install sysstat -y
安装完成后,执行以下命令查看磁盘IO统计:
# 每隔1秒输出一次磁盘统计,共输出3次 iostat -x 1 3
其中-x参数会输出扩展的磁盘统计信息,重点关注%util指标,该指标表示磁盘的繁忙程度,数值接近100%说明磁盘IO已经饱和。
监控网络性能
如果需要监控网络带宽使用情况,可以使用sar命令,同样属于sysstat工具包:
# 查看网卡eth0的每秒接收和发送流量,每隔1秒输出一次,共输出5次 sar -n DEV 1 5 | grep eth0
输出结果中的rxpck/s表示每秒接收的数据包数,txpck/s表示每秒发送的数据包数,rxkB/s和txkB/s分别表示每秒接收和发送的千字节数。
自定义监控脚本示例
如果需要定期记录系统性能数据,可以编写简单的shell脚本实现:
#!/bin/bash
# 定义日志文件路径
LOG_FILE="/var/log/system_perf.log"
# 每隔10秒记录一次top的快照,共记录10次
for i in {1..10}
do
echo "===== 记录时间: $(date '+%Y-%m-%d %H:%M:%S') =====" >> $LOG_FILE
top -b -n 1 | head -20 >> $LOG_FILE
sleep 10
done
上述脚本会以批处理模式运行top命令,每次记录前20行核心信息到日志文件中,方便后续排查历史性能问题。