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

简单邮件传输协议 (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@localhost /]# 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 [email protected] test 123
![](https://s1.51cto.com/images/blog/201909/12/90d74346e00511b6a1b12d0d102c8369.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)
四、常见问题及处理:
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。(时间请根据需求设定)
下图为报警信息
![](https://s1.51cto.com/images/blog/201909/12/fdba3e66ac5dfcee2a987678cad81bab.png?x-oss-process=image/watermark,size_16,text_QDUxQ1RP5Y2a5a6i,color_FFFFFF,t_100,g_se,x_10,y_10,shadow_90,type_ZmFuZ3poZW5naGVpdGk=)
以上就是使用stmp+shell实现简单的服务器存活状态监控。
博主小白,欢迎各位指出不足和改进意见,感谢观看。

猜你喜欢

转载自blog.51cto.com/14015577/2437723