前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >shell脚本实现Linux磁盘空间超过阈值自动钉钉机器人告警

shell脚本实现Linux磁盘空间超过阈值自动钉钉机器人告警

作者头像
yuanfan2012
发布2024-03-21 17:18:00
1430
发布2024-03-21 17:18:00
举报
文章被收录于专栏:WalkingCloudWalkingCloud

shell脚本实现Linux磁盘空间超过阈值自动钉钉机器人告警

具体步骤如下

1、创建钉钉Webhook机器人

安全设置这里我选用服务器出口IP

设定后,只有来自IP地址范围内的请求才会被正常处理

(图片点击放大查看)

(图片点击放大查看)

(图片点击放大查看)

2、编写磁盘巡检脚本

代码语言:javascript
复制
vim /opt/disk_usage_check.sh 

#!/bin/bash

# 设置警告阈值
THRESHOLD=80

#
CURRENT_TIME=$(date +"%Y-%m-%d %H:%M:%S")
# 获取主机名和IP
HOSTNAME=$(hostname)
IP=$(hostname -I)

# 筛选需要检查的磁盘并进行检查
df -lPh | grep -vE '^Filesystem|tmpfs|cdrom' | awk '{ print $5 " " $1 }' | while read output;
do
  used=$(echo $output | awk '{print $1}' | cut -d'%' -f1)
  partition=$(echo $output | awk '{print $2}')

  if (( used >= THRESHOLD )); then
    # 构建payload
    PAYLOAD=$(cat <<-EOF
{       
"msgtype": "markdown",
"markdown": {
"title":"Linux服务器磁盘空间告警",
"text":"
##### Linux服务器磁盘空间告警 \n
>  ##### <font color=#67C23A> 【服务器: </font> <font color=#FF0000> $HOSTNAME</font>】 的磁盘空间超过阀值</font> :<font color=#FF0000> $THRESHOLD%  </font> \n
>  ##### <font color=#67C23A> 【服务器IP】</font> :<font color=#FF0000> $IP </font> \n
>  ##### <font color=#67C23A> 【告警时间】</font> :<font color=#FF0000> $CURRENT_TIME </font> \n
>  ##### <font color=#67C23A> 【磁盘空间占用高的分区】:<font color=#FF0000> $partition </font> 已使用 <font color=#FF0000>$used%</font> \n
>  ##### <font color=#67C23A>  该分区具体df -PTh信息如下: </font> \n
>  ##### <font color=#FF0000>  $(df -lPTh | head -n 1) </font> \n
>  ##### <font color=#FF0000>  $(df -lPTh| grep $partition) </font> \n
"
}
}
EOF
    )

    # 发送告警 (自行替换钉钉Webhook机器人的URL)
    curl -H "Content-Type: application/json" -X POST -d "$PAYLOAD"  https://oapi.dingtalk.com/robot/send?access_token=XXXXXXXXXX
    echo $PAYLOAD
  fi
done

3、脚本权限设置及定时任务设置

代码语言:javascript
复制
chmod 777 /opt/disk_usage_check.sh

crontab -e 
0 */4 * * * /opt/disk_usage_check.sh

(图片点击放大查看)

(图片点击放大查看)

每4个小时巡检一次 可以自行调整频率

4、测试

代码语言:javascript
复制
df -PTh

找一个分区,以/boot分区为例

代码语言:javascript
复制
dd if=/dev/zero of=/boot/test.iso count=1 bs=300M

让/boot分区超过阀值进行测试 然后手动执行

代码语言:javascript
复制
sh /opt/disk_usage_check.sh

测试是否会触发告警

(图片点击放大查看)

5、告警效果如下

(图片点击放大查看)

本文参与?腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2023-12-13,如有侵权请联系?cloudcommunity@tencent.com 删除

本文分享自 WalkingCloud 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1、创建钉钉Webhook机器人
  • 2、编写磁盘巡检脚本
  • 3、脚本权限设置及定时任务设置
  • 4、测试
  • 5、告警效果如下
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
http://www.vxiaotou.com