centos cpustat如何实现自动化监控

要在 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
喜欢就支持一下吧
点赞6 分享