简单邮件传输协议 (Simple Mail Transfer Protocol, SMTP) 是在Internet传输email的事实标准,
SMTP是一个相对简单的基于文本的协议。在其之上指定了一条消息的一个或多个接收者,然后消息文本会
被传输。SMTP使用TCP端口25。
一、配置环境
[[email protected] ~]# cat /etc/redhat-release
CentOS Linux release 7.5.1804 (Core)
#查看系统环境
[[email protected] ~]# systemctl stop firewalld
#停止firewall防火墙服务
[[email protected] ~]# systemctl disable firewalld
#禁止firewall防火墙服务开机自动启动功能
[[email protected] ~]# firewall-cmd --state
not running
#查看防火墙运行状态,确认防火墙被关闭。
vi /etc/selinux/config
#SELINUX=enforcing
#SELINUXTYPE=targeted
SELINUX=disabled
:wq!
#关闭selinux,保存退出
[[email protected] ~]# setenforce 0
#临时关闭selinux,重启失效
[[email protected] ~]# getenforce
Disabled
#查看selinux状态,确认已关闭
二、下载软件,并安装相关依赖的perl组件
[[email protected] ~]# yum -y install perl-Net-SSLeay perl-IO-Socket-SSL
#安装依赖
[[email protected] ~]# wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz
#下载安装包
[[email protected] ~]# tar -zxf sendEmail-v1.560.tar.gz
#解压安装包
[[email protected] ~]# cd sendEmail-v1.56/
[[email protected] sendEmail-v1.56]# ls
CHANGELOG README README-BR.txt sendEmail sendEmail.pl TODO
#进入目录sendEmail-v1.56/
[[email protected] sendEmail-v1.56]# cp sendEmail /usr/local/bin/sendEmail
[[email protected] sendEmail-v1.56]# chown root:root /usr/local/bin/sendEmail
[[email protected] 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用户权限、属组权限
三、创建脚本并赋予脚本执行权限
[[email protected] ~]# cd
[[email protected] ~]# pwd
/root
#返回/root
[[email protected] ~]# 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 ********表示邮件协议授权密钥
[[email protected] ~]# chmod +x mail.sh
#执行脚本测试发送邮件
[[email protected] ~]# ./mail.sh [email protected] 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脚本进行服务器在线状态监控
[[email protected] ~]# 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
[[email protected] ~]# 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实现简单的服务器存活状态监控。
博主小白,欢迎各位指出不足和改进意见,感谢观看。
原文地址:https://blog.51cto.com/14015577/2437723