1 mail环境搭建
1.1 安装mail套件
ubuntu环境:apt-get install mutt msmtp
centos环境:我没有采用mutt,是用的sendmail或mail中的一种,有需要的同学可以参考这里。
1.2 配置
1.2.1 MUTT
系统全局设置/etc/Muttrc,如果使用某个系统用户,可以在~/.muttrc中设置。
vi .muttrc
set sendmail="/usr/bin/msmtp"
set use_from=yes
set realname="20043790"
set from=20043790@163.com
set envelope_from=yes
1.2.2 MSMTP
创建~/.msmtprc和~/.msmtp.log,分别为配置和日志文件。vi .msmtprc
account default
host smtp.163.com
from 20043790@163.com
auth plain
user 20043790
password 123456
logfile ~/.msmtp.log
由于password是明码,所以我们需要修改此文件的权限。
chmod 600 .msmtprctouch ~/.msmtp.log
1.2.3 验证邮件服务器
查看SMTP服务器是否支持认证的TLS加密:
敲入如下命令:msmtp --host=smtp.163.com --serverinfo回车1.3 测试
1.3.1 发一封邮件
1.3.2 QQ PC客户端邮件提醒
1.3.3 微信邮件提醒
2 linux守护脚本
[root@root src]# cat daemon.sh
[root@root src]# cat daemon.sh
#!/bin/sh
programs="app1 app2 app3"
while true
do
for p in $programs
do
ps -e|grep $p |grep -v "grep" >/dev/null
if [ "$?" -ne 0 ]
then
timestr=`date +20%y%m%d_%H%M%S`
echo "Time:$timestr, restart <$p>"
/root/src/$p >/root/src/log/${p}_$timestr.log 2>&1 &
echo "Unfortunately, $p restart."|mail -s warning_restart 412493505@qq.com -- -f 20043790@163.com
#else
#echo "$p is running"
fi
done
sleep 1
done
我的云主机是centos的,用的是mail发邮件,同样可以用mutt的命令行发送方式。
该守护脚本守护三个程序 app1-3,当有某一个程序死掉后,重启该程序并开启新的log,同时发邮件到指定的邮箱。
3 验证
killall app1后,守护脚本在1秒内将程序重启,约15秒后收到邮件提醒。
来源:oschina
链接:https://my.oschina.net/u/616273/blog/205965