这是一个用于监控服务器磁盘利用率的shell脚本,它的功能和意义如下:
- 第一行是一个特殊的注释,用于指定执行这个脚本的解释器,这里是bash。
- 第三行到第十行是一些变量的定义,用于设置监控的参数,比如要监控哪些磁盘分区,报警的阈值是多少,检测的频率是多少,日志文件的位置和名称是什么等。
- 第十二行到第二十四行是一个函数的定义,叫做send_mail,它的作用是发送邮件给指定的收件人,告知他们哪些磁盘分区已经超过了阈值。这个函数需要一个参数,就是超过阈值的分区名称和利用率。
- 第二十六行到第四十八行是另一个函数的定义,叫做monitor_disk,它是主循环函数,它的作用是不断地检测磁盘利用率,并且如果发现有超过阈值的情况,就调用send_mail函数发送邮件,并且记录日志文件。这个函数没有参数,但是会使用前面定义的一些变量。
- 第五十行是调用monitor_disk函数的语句,这样就可以开始执行监控任务了。
#!/bin/bash
# 监控服务器磁盘利用率的shell脚本
# 定义要监控的磁盘分区,可以有多个,用空格隔开
PARTITIONS="/dev/sda1 /dev/sdb1"
# 定义报警阈值,单位为百分比
THRESHOLD=80
# 定义检测频率,单位为秒
INTERVAL=60
# 定义日志文件的路径和名称
LOGFILE=/tmp/disk_monitor.log
# 定义邮件发送函数,需要安装mailx命令
send_mail(){
# 定义收件人邮箱地址,可以有多个,用空格隔开
MAILTO="user1@example.com user2@example.com"
# 定义邮件主题
SUBJECT="Disk Usage Alert"
# 定义邮件正文
MESSAGE="The following partitions have reached the threshold of $THRESHOLD%: $1"
# 发送邮件
echo $MESSAGE | mailx -s "$SUBJECT" $MAILTO
}
# 定义主循环函数
monitor_disk(){
while true
do
# 获取当前时间
DATE=$(date "+%Y-%m-%d %H:%M:%S")
# 遍历要监控的磁盘分区
for PARTITION in $PARTITIONS
do
# 获取磁盘利用率,去掉百分号
USAGE=$(df -h | grep $PARTITION | awk '{print $5}' | sed 's/%//')
# 判断是否超过阈值
if [ $USAGE -ge $THRESHOLD ]
then
# 记录日志文件
echo "$DATE $PARTITION usage: $USAGE%" >> $LOGFILE
# 调用邮件发送函数,传入超过阈值的分区名称和利用率
send_mail "$PARTITION usage: $USAGE%"
fi
done
# 等待一定时间后再次检测
sleep $INTERVAL
done
}
# 调用主循环函数
monitor_disk
</div>