目录
背景
实现思路
邮件4小时内只会发送一次,如果执行了发送邮件的脚本,就使用sed命令将对应的调用代码置为无效
请求脚本
Python邮件发送脚本
定时任务设置
恢复邮件发送能力脚本
资料获取方法
背景
由于一些原因,博主负责测试的网站的服务器切换到了香港,切换后出现了多次访问超时的情况
于是主动请缨写一个自动监测的脚本,本来准备完全使用shell来写,后来发现shell发送邮件只能在测试机之间进行,所以添加了增加了一个Python文件来完成该功能。
实现思路
使用Linux系统自带的定时模块crontab,设置每隔五分钟调用一次检查脚本检查服务,如果发现异常,调用Python脚本发送邮件
邮件4小时内只会发送一次,如果执行了发送邮件的脚本,就使用sed命令将对应的调用代码置为无效
- 邮件接受人和需要监控的url都放在配置文件中,方便后续扩展。
- 使用crontab的好处是,只要系统在运行,脚本就能正常运行。
请求脚本
#! /bin/bash
#把所有标准输出重定向到到日志文件中
exec 1>>/home/XXX/Monitor/cfg.log
#获取配置文件中的url
urls=`cat /home/XXX/Monitor/url.inc|grep -v '#'`
for i in ${urls}
do
#获取页面返回码
result=`curl -I -m 10 -o /dev/null -s -w %{http_code} ${i}`
#日志内容(标准输出)
date;echo ${result};echo $i ;echo '-----------------------------'
#判断数据是否异常,如果异常就调用发送邮件的脚本,
#只发送一次邮件,如果执行了发送邮件的代码,就将该段代码置为无效
[ "$result" = 200 ] && `python /home/XXX/Monitor/mail_sender.py $i ${result}` && `sed -i 's/\&\&/\#\#/' /home/XXX/Monitor/request.sh`
done
Python邮件发送脚本
#! /bin/bash
#把所有标准输出重定向到到日志文件中
exec 1>>/home/XXX/Monitor/cfg.log
#获取配置文件中的url
urls=`cat /home/XXX/Monitor/url.inc|grep -v '#'`
for i in ${urls}
do
#获取页面返回码
result=`curl -I -m 10 -o /dev/null -s -w %{http_code} ${i}`
#日志内容(标准输出)
date;echo ${result};echo $i ;echo '-----------------------------'
#判断数据是否异常,如果异常就调用发送邮件的脚本,
#只发送一次邮件,如果执行了发送邮件的代码,就将该段代码置为无效
[ "$result" = 200 ] && `python /home/XXX/Monitor/mail_sender.py $i ${result}` && `sed -i 's/\&\&/\#\#/' /home/XXX/Monitor/request.sh`
done
定时任务设置
crontab -e 打开定时任务编辑器,添加下面两行
*/5 * * * * bash /home/brenda/CFG_Monitor/request.sh >> /home/brenda/CFG_Monitor/cfg.log
* */4 * * * bash /home/brenda/CFG_Monitor/recover.sh >> /home/brenda/CFG_Monitor/cfg.log
恢复邮件发送能力脚本
#! /bin/bash
sed -i '/\[/{s/\#\#/\&\&/g}' /home/XXX/Monitor/request.sh
资料获取方法
【留言777】
各位想获取源码等教程资料的朋友请点赞 + 评论 + 收藏,三连!
三连之后我会在评论区挨个私信发给你们~