在 DBA 日常运维中,实时监控是最必备的技能。它可以帮助我们:

快速定位 CPU/内存 瓶颈监控 I/O 消耗查看网络连接状态本篇我们集中讲解四大监控利器:

top:系统进程、资源实时概览htop:top 的可视化增强版iotop:监控进程 I/O 行为netstat:网络连接与端口状态查看环境说明

操作系统:AlmaLinux 8.x数据库:MySQL 一主两从,均部署在 Docker 容器中脚本目录:scripts/monitoring二、准备工作:创建目录 & 命令检查登录到主服务器(master)

ssh dba@master.example.com

创建监控脚本存放目录

mkdir-p scripts/monitoring

cd scripts/monitoring

检查四大命令是否可用

for cmd intophtop iotop netstat;do

command -v $cmd>/dev/null >&1

if[$?-ne];then

echo "未检测到命令 $cmd,安装请执行:"

case $cmd in

top)echo " yum install -y procps-ng";;

htop)echo " yum install -y htop";;

iotop)echo " yum install -y iotop";;

netstat)echo " yum install -y net-tools";;

esac

else

echo"✅ $cmd 已安装"

fi

done

若出现 bash: iotop: 未找到命令,就按照提示安装并重新登录或刷新 PATH。图片三、top:最基础的系统监控工具3.1 启动 top代码语言:javascript复制

top

界面示例

图片top 实时界面

3.2 常用快捷键快捷键

功能

P

按 CPU 占用排序

M

按内存占用排序

T

按运行时间排序

1

显示所有 CPU 核心使用情况

q

退出 top

3.3 排查 “bash: top: 未找到命令”代码语言:javascript复制

yum install-y procps-ng

安装后,再次运行 top即可。

四、htop:彩色可视化,操作更友好4.1 启动 htop代码语言:javascript复制

htop

支持上下左右方向键支持 F3/F4 过滤、F6 列排序支持用鼠标滚动(如果终端支持)4.2 安装代码语言:javascript复制

yum install-y epel-release

yum install-yhtop

4.3 报错排查bash: htop: 未找到命令→ 确认已启用 EPEL 源并安装如果界面乱码,检查终端字符集为 UTF-8图片五、iotop:实时监控 I/O 消耗5.1 启动 iotop代码语言:javascript复制

sudo iotop

需要 root 权限或具有 CAP_SYS_ADMIN权限的用户。

5.2 常用参数代码语言:javascript复制只显示当前有 I/O 活动的进程代码语言:javascript复制

sudo iotop -o-d> iotop.log

5.3 安装 & 排查代码语言:javascript复制

yum install-y iotop

若报 bash: iotop: 未找到命令,按上述安装若报 IOPRIO_CLASS: Operation not permitted,请加 sudo或提升权限六、netstat:查看网络连接与端口注意:AlmaLinux 8 默认推荐使用 ss,但 netstat更直观

6.1 基本用法代码语言:javascript复制

netstat-tunlp

代码语言:javascript复制TCP 连接示例输出

图片netstat 输出示例

6.2 报错排查bash: netstat: 未找到命令→

yum install-y net-tools

若显示 You must be root to see process info,请加 sudo七、脚本化:把监控命令做成自动报告下面给出一个简单的例子:每天凌晨 1 点收集一次系统状态

脚本:daily_monitor.sh

代码语言:javascript复制

#!/bin/bash

OUTDIR="/home/dba/dba-scripts/monitoring/reports/$(date +%F)"

mkdir-p"$OUTDIR"

# top 快照

top-b-n>"$OUTDIR/top_$(date +%H%M).txt"

# iotop 快照(需 sudo)

sudo iotop -b-n-d>"$OUTDIR/iotop_$(date +%H%M).txt"

# netstat 快照

netstat-tunlp>"$OUTDIR/netstat_$(date +%H%M).txt"

echo"监控报告已生成在 $OUTDIR"

赋权并测试:

代码语言:javascript复制

chmod +x daily_monitor.sh

./daily_monitor.sh

无报错则成功生成报告。

八、配置定时:crontab 自动执行编辑 crontab:

代码语言:javascript复制crontab-e添加:

代码语言:javascript复制***/home/dba/dba-scripts/monitoring/daily_monitor.sh>>/home/dba/dba-scripts/monitoring/monitor.log>&保存后执行 crontab -l确认生效。

下篇我们将深入讲解如何利用 Prometheus + Grafana构建可视化监控平台,敬请期待! (脚本为服务器复制可能有空格问题,手敲完印象深刻)