1 项目背景为,服务器上会定时拉去实时数据文件,文件夹内有记录当前数据最新批次时间如下格式
2022-03-11 23:26:00 ,实现思路是把txt中时间转化为时间戳和当前时间戳比对,如果时间大于10分钟,说明实时数据拉取有异常,然后将数据未更新消息发生钉钉群里,
可以迁移扩展为 : 内存 使用率 ,磁盘使用率,服务端口异常等监控钉钉群报警
2 如何建立钉钉机器人报警,并生成token值,可以自行百度
3 脚本详情如下
#!/bin/bash
txtDate=$(cat /home/basedata/last-date.txt)
#last-date.txt 会记录文件最新下载批次时间
echo "txt中时间为:" $txtDate
txtTimeStamp=`date -d "$txtDate" +%s`
echo "txt日期时间戳: " $txtTimeStamp
currentDate=`date "+%Y-%m-%d %H:%M:%S"`
echo "当前日期:" $currentDate
currentTimeStamp=`date -d "$currentDate" +%s`
echo "当前日期时间戳:" $currentTimeStamp
cha=$(($currentTimeStamp-$txtTimeStamp))
echo $cha
if [ $cha -gt 600 ];then
# access_token 后面需要填写你实际钉钉群的token值,才会发到相应钉钉群
curl 'https://oapi.dingtalk.com/robot/send?access_token=xxxxxxxxx' \
-H 'Content-Type: application/json' \
-d '{"msgtype": "text","text": {"content": "业务报警: 实时文件已超过10分钟未更新,需检查!"}}'
echo $currentDate "实时文件已超过10分钟未更新,需检查!" >>/home/info.log
else
echo $currentDate "数据正常更新中" >>/home/info.log
fi
4 添加定时任务,定时检查,有异常自动报警,
chmod +x /home/dateCheck.sh
crontab -e 添加
*/10 * * * * sh /home/dateCheck.sh