码迷,mamicode.com
首页 > 系统相关 > 详细

linux下使用smtp+shell脚本实现服务器存活状态监控

时间:2019-09-12 16:35:37      阅读:212      评论:0      收藏:0      [点我收藏+]

标签:下载软件   prot   usr   $2   出现   start   dem   问题   客户端   

简单邮件传输协议 (Simple Mail Transfer Protocol, SMTP) 是在Internet传输email的事实标准, SMTP是一个相对简单的基于文本的协议。在其之上指定了一条消息的一个或多个接收者,然后消息文本会 被传输。SMTP使用TCP端口25。 一、配置环境 [root@ser ~]# cat /etc/redhat-release CentOS Linux release 7.5.1804 (Core) #查看系统环境 [root@ser ~]# systemctl stop firewalld #停止firewall防火墙服务 [root@ser ~]# systemctl disable firewalld #禁止firewall防火墙服务开机自动启动功能 [root@ser ~]# firewall-cmd --state not running #查看防火墙运行状态,确认防火墙被关闭。 vi /etc/selinux/config #SELINUX=enforcing #SELINUXTYPE=targeted SELINUX=disabled :wq! #关闭selinux,保存退出 [root@ser ~]# setenforce 0 #临时关闭selinux,重启失效 [root@ser ~]# getenforce Disabled #查看selinux状态,确认已关闭 二、下载软件,并安装相关依赖的perl组件 [root@ser ~]# yum -y install perl-Net-SSLeay perl-IO-Socket-SSL #安装依赖 [root@ser ~]# wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz #下载安装包 [root@ser ~]# tar -zxf sendEmail-v1.560.tar.gz #解压安装包 [root@ser ~]# cd sendEmail-v1.56/ [root@ser sendEmail-v1.56]# ls CHANGELOG README README-BR.txt sendEmail sendEmail.pl TODO #进入目录sendEmail-v1.56/ [root@ser sendEmail-v1.56]# cp sendEmail /usr/local/bin/sendEmail [root@ser sendEmail-v1.56]# chown root:root /usr/local/bin/sendEmail [root@ser sendEmail-v1.56]# ll /usr/local/bin/sendEmail -rwxr-xr-x 1 root root 80183 Jul 31 15:14 /usr/local/bin/sendEmail #将sendEmail复制到执行目录/usr/local/bin/下,并赋予root用户权限、属组权限 三、创建脚本并赋予脚本执行权限 [root@ser ~]# cd [root@ser ~]# pwd /root #返回/root [root@ser ~]# vim mail.sh #!/bin/bash to=$1 subject=$2 body=$3 /usr/local/bin/sendEmail -o tls=auto -f ******@qq.com -t "$to" -s smtp.qq.com -u "$subject" -o message-content-type=html -o message-charset=utf8 -xu ******@qq.com -xp ****** -m "$body" #脚本中 -f ********@qq.com表示发件人邮箱,-s smtp.qq.com 表示邮件的smtp服务器 #本文中使用腾讯qq邮箱,使用其他邮箱服务器需要修改 # -xu ********@qq.com 表示发件人邮箱的用户名,-xp ********表示邮件协议授权密钥 [root@ser ~]# chmod +x mail.sh #执行脚本测试发送邮件 [root@ser ~]# ./mail.sh chao.il@qq.com test 123 test 发件人:**<********@qq.com> 时 间:2019年9月12日(星期四) 下午3:50 (UTC+0:00 伦敦、都柏林、里斯本时间) 收件人:** <********@qq.com> 123 #收到的测试邮件 四、常见问题及处理: 1、当进行邮件测试时,出现invalid SSL_version ******/IO/Socket/SSL.pm line 444这样的报错时, 原因是sendEmail软件和perl里面的SSL版本不兼容导致,通过修改/usr/local/bin/sendEmail文件第 1906行,不指定SSL版本,原始文件为 if (! IO::Socket::SSL->start_SSL($SERVER, SSL_version => ‘SSLv3 TLSv1‘)) { 更改后为 if (! IO::Socket::SSL->start_SSL($SERVER)) { 2、当进行邮件测试,出现ERROR => SMTP-AUTH: Authentication to smtp.qq.com:25 failed这样 的报错时,原因是邮箱要求使用第三方客户端发送邮件是必须使用授权码登录的,使用帐号密码验证时,授 权码需要登录邮箱设置中查找,有些邮件服务器需要先开启POP3服务。 五、编写shell脚本进行服务器在线状态监控 [root@ser ~]# vim CheckNetwork.sh #!/bin/bash tt1=172.20.220.20 #定义服务器一 tt2=172.20.11.1 #定义服务器二 while true #while(true)是一个无穷循环语句 #我们必须在他的循环语句内部加入一个判断,当他达到了什么要求就会跳出 do ping -c 5 $tt1 >/dev/null #用ping命令来探测远程机是否存活 if [ $? -eq 0 ];then #shell脚本中$?是指上一次命令执行的成功或者失败的状态。如果成功就是0,失败为1。 #语句if [ $? -eq 0 ] 是判断if语句的上一个命令执行如果失败就执行if中的语句,否则就执行else中的内容。 echo `date +%F-%T` " $tt1 is yes" >> ip_yes.txt #追加当前时间和服务器IP is yes 到ip_yes.txt,此处ip_yes.txt用做正确日志文件 else echo `date +%F-%T` " $tt1 is Error" >> ip_no.txt #追加当前时间和服务器IP is Error到ip_no.txt,此处ip_no.txt用做错误日志文件 /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error" /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error" /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error" /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"爱普 $tt1 is Error" #发送邮件给以上的邮件地址 sleep 5 #休眠5秒 fi ping -c 5 $tt2 >/dev/null if [ $? -eq 0 ];then echo `date +%F-%T` " $tt2 is yes" >> ip_yes.txt else echo `date +%F-%T` " $tt2 is Error" >> ip_no.txt /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error" /root/mail.sh ********@qq.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error" /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error" /root/mail.sh ********@sunplusapp.com 服务器错误 `date +%F-%T`----"益辉 $tt2 is Error" sleep 5 fi kill -9 `ps aux | grep CheckNetwork | grep -v grep | awk ‘{print $2}‘` #执行脚本后,杀死此脚本的进程,防止重复执行脚本。 done [root@ser ~]# crontab -l */15 8-18 * * * /usr/bin/bash /root/CheckNetwork.sh #设置定时任务,8点到18点每15分钟执行CheckNetwork.sh。(时间请根据需求设定) 下面为报警邮件信息 服务器错误 发件人:** <********@qq.com> 时 间:2019年9月12日(星期四) 下午4:45 (UTC+0:00 伦敦、都柏林、里斯本时间) 收件人:** <********@qq.com> 2019-09-12-12:45:19----益辉 172.20.11.1 is Error 以上就是使用stmp+shell实现简单的服务器存活状态监控。 博主小白,欢迎各位指出不足和改进意见,感谢观看。

linux下使用smtp+shell脚本实现服务器存活状态监控

标签:下载软件   prot   usr   $2   出现   start   dem   问题   客户端   

原文地址:https://blog.51cto.com/14015577/2437723

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!