利用mail实时监测服务器程序状态

2022-06-30 18:07:14 浏览数 (1)

摘要 近期服务器程序正在调试,不能一天到晚远程连到服务器上瞅着,因此利用 <linux监测脚本 mail命令 qq邮箱 微信> 做到实时检测远程的服务器程序状态,当程序down掉之后保证我们能快速收到提醒。

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 .msmtprc

touch ~/.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秒后收到邮件提醒。

0 人点赞