linux利用mailx发送告警邮件提示断网
先规划流程
1. 邮箱开启POP3/SMTP/IMAP服务自行研究这里用腾讯QQ邮箱作为演示smtp.qq.com
2. 系统安装mailx 工具
3.编写相关循环检测某个外网地址
环境:
CentOS7.6 双网其中一路可以访问外网邮件服务器,同时内网业务需要保证网络在线。
yum install mailx -y
之后打开配置文件在最后一行添加SMTP 服务器信息
vim /etc/mail.rc
# set smtp address
set from="你的邮箱地址@qq.com"
set smtp="smtp.qq.com" # 这里填QQ的服务器请自己修改
set smtp-auth-user="你的邮箱地址@qq.com"
set smtp-auth-password="开通STMP服务器时候给的加密密码"
set smtp-auth=login
之后wq保存测试一下发送邮件,注意 前面是邮件内容 “|” 后面是邮件标题
echo -e "专线网络已断开,请检查" | mail -s 'network error' 收件人的邮箱地址@qq.com
编写shell 脚本,这种脚本网上很多我就不重复造轮子了直接找了个大佬写好的修改了一下,诸位请自行修改相关告警内容和发送地址即可
vim mailStmp.sh
#!/usr/bin/env bash
#初始化环境变量
source /root/.bash_profile
#邮件发送列表
mail_list='收件人的邮箱地址@qq.com'
#ping三次检测的ip
ping=`ping -c 3 70.4.0.1|awk 'NR==7 {print $4}'`
#如果三次均没ping通,则做以下操作
if [ $ping -eq 0 ]
then
#检查mailinfo文件是否存在,不存在则建立
if [ ! -e ./mailinfo ]
then
touch ./mailinfo
fi
#获取当前主机时间,用于邮件正文的时间显示
now_time=`date`
#检查./mailinfo的行数是否为空,如果为空则直接发送邮件
row_num=`wc -l ./mailinfo | cut -c 1`
if [ $row_num -eq 0 ]
then
echo "发邮件"
echo -e "专线网络已断开,请检查 \n\n 告警时间:$now_time" |mail -s 'network error' $mail_list
#更新最后一次发送时间
date +%Y%m%d-%H%M > ./mailinfo
echo 1 >> ./mailinfo
#如果mailinfo内容不为空,则判断(当前时间减1小时)是否大于上次发送时间,如果是则发邮件
else
#获取上次发邮件的日期和时间
last_date=`head -1 ./mailinfo | cut -c 1-8`
last_time=`head -1 ./mailinfo | cut -c 10-13`
#获取1小时前的日期和时间
current_date=`date +%Y%m%d`
current_time=`date +%H%M`
#计算当前时间和上次时间差距多久,加10#是为了防止0开头的字符被当成8进制计算
let time_diff=10#$current_time-10#$last_time
#获取发送次数
send_times=`tail -1 ./mailinfo`
#以下四种情况发邮件:
#当前日期>上次日期,可以发,然后发送计数send_times置为1
if [ "$current_date" -gt "$last_date" ]
then
echo "发邮件"
echo -e "专线网络已断开,请检查 \n\n 告警时间:$now_time" |mail -s 'luchen network error' $mail_list
#更新最后一次发送时间
date +%Y%m%d-%H%M > ./mailinfo
echo 1 >> ./mailinfo
fi
#当前日期等于上次日期 and 本次时间大于上次时间1小时外,可以发,然后发送计数send_times置为1
if [ "$current_date" -eq "$last_date" -a $time_diff -ge 100 ]
then
echo "发邮件"
echo -e "70专线网络已断开,请检查 \n\n 告警时间:$now_time" |mail -s 'network error' $mail_list
#更新最后一次发送时间
date +%Y%m%d-%H%M > ./mailinfo
echo 1 >> ./mailinfo
fi
#当前日期等于上次日期 and 发送计数send_times置为1,可以发,然后发送次数加1
if [ "$current_date" -eq "$last_date" -a $send_times -eq 1 ]
then
echo "发邮件"
echo -e "70专线网络已断开,请检查 \n\n 告警时间:$now_time" |mail -s 'network error' $mail_list
#更新最后一次发送时间
date +%Y%m%d-%H%M > ./mailinfo
echo 2 >> ./mailinfo
fi
#当前日期等于上次日期 and 发送计数send_times置为2,可以发,然后发送次数加1
if [ "$current_date" -eq "$last_date" -a $send_times -eq 2 ]
then
echo "发邮件"
echo -e "专线网络已断开,请检查 \n\n 告警时间:$now_time" |mail -s 'network error' $mail_list
#更新最后一次发送时间
date +%Y%m%d-%H%M > ./mailinfo
echo 3 >> ./mailinfo
fi
fi
fi
写好后也请先断网手动触发测试一下shell 脚本
bash mailStmp.sh
crontab -e 定时任务内新增一条
# 每小时执行一次检测专线是否有问题并邮件告警
0 */1 * * * /home/root/mailStmp.sh >> /tmp/maliStmpLog.log 2>&1