要在 centos 上使用 cpustat 实现自动化监控,可以通过 cron 定时任务与脚本编写来完成。以下是具体操作步骤:
1. 安装 sysstat 包
请首先确认是否已安装 sysstat 工具包,因为 cpustat 属于该组件的一部分。
sudo yum install sysstat -y
2. 创建监控脚本
新建一个脚本文件,例如 /usr/local/bin/monitor_cpu.sh,并写入如下内容:
#!/bin/bash # 设置日志输出路径 output_file="/var/log/cpu_usage.log" # 获取当前时间戳 timestamp=$(date "%Y-%m-%d %H:%M:%S") # 使用 cpustat 命令获取 CPU 使用情况并添加时间戳 cpustat -c 1 1 | awk 'NR>1 {print $0 " " timestamp}' >> "$output_file"
说明:
- cpustat -c 1 1:每秒采集一次数据,共采集一次。
- awk ‘NR>1 {print $0 ” ” timestamp}’:忽略首行标题,并在每行末尾附加时间信息。
- >> “$output_file”:将结果追加写入日志文件中。
3. 赋予脚本执行权限
sudo chmod +x /usr/local/bin/monitor_cpu.sh
4. 配置定时任务
通过 cron 来周期性地运行脚本。编辑当前用户的 crontab 文件:
crontab -e
插入以下语句以实现每分钟自动运行一次脚本:
* * * * * /usr/local/bin/monitor_cpu.sh
保存并退出编辑器。
5. 确认定时任务状态
确保 cron 服务处于运行状态,并且任务配置无误:
sudo systemctl status crond
查看生成的日志文件内容:
tail -f /var/log/cpu_usage.log
6. 可选:配置邮件告警机制
若需要在 CPU 使用率过高时接收通知,可在脚本中加入邮件发送逻辑。比如使用 mail 命令实现:
#!/bin/bash # 设置日志输出路径 output_file="/var/log/cpu_usage.log" # 获取当前时间戳 timestamp=$(date "%Y-%m-%d %H:%M:%S") # 使用 cpustat 获取 CPU 使用情况并附带时间戳 cpu_usage=$(cpustat -c 1 1 | awk 'NR>1 {print $0 " " timestamp}') # 写入日志文件 echo "$cpu_usage" >> "$output_file" # 判断 CPU 使用率是否超过设定阈值(如 80%) if [[ $(echo "$cpu_usage" | awk '{print $3}') > 80 ]]; then # 发送告警邮件 echo "CPU usage is high: $cpu_usage" | mail -s "High CPU Usage Alert" your_email@example.com fi
注意:需提前配置好邮件发送环境(如 postfix 或 sendmail),并确保系统支持 mail 命令。
按照上述步骤操作后,即可在 centos 中实现基于 cpustat 的自动化性能监控,并可依据需求设置异常告警机制。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END