【Linux】结合Python 简易实现监控公司网站,邮件发送异常

目录

背景

实现思路

邮件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】

各位想获取源码等教程资料的朋友请点赞 + 评论 + 收藏,三连!

三连之后我会在评论区挨个私信发给你们~

猜你喜欢

转载自blog.csdn.net/GDYY3721/article/details/132148498
今日推荐