本文共 1594 字,大约阅读时间需要 5 分钟。
实时监控邮件服务器的状态需要脚本任务做支撑
#!/bin/bash
#Purpose: Check Postfix and Pop3 MySQL service status #Author: andylhz #Date: 2010-07-29 dt=`date '+%Y:%m:%d:%H:%M'` mailer=root@test.cn mailer2=138XXXXXXXX@139.com host=mail.test.cn#Dovecot服务的检查 存在则发邮件显示正常,否则就重启服务
dovecot=`ps aux |grep pop3-login | grep -v "grep" |awk {'print $11'} | uniq` if [ "$dovecot" == "pop3-login" ]; then echo "$dt <$host> pop3 service is ok!" >/tmp/pop_ok; mail -s "pop3-OK(IP-154)" $mailer < /tmp/pop_ok; else echo "$dt <$host> pop3 service is down! will start!" >/tmp/pop_down; mail -s "pop3-down(IP-)" -c $mailer2 $mailer < /tmp/pop_down; service dovecot start; fi#postfix服务的检查 存在则发邮件显示正常,否则就重启服务 postfix=`ps aux |grep postfix | grep -v "grep" |grep -v "root"| awk {'print $1'} | uniq` if [ "$postfix" == "postfix" ]; then echo "$dt <$host> postfix service is ok!" >/tmp/postfix_ok; mail -s "postfix-OK(IP)" $mailer < /tmp/postfix_ok; else echo "$dt <$host> postfix service is down! will start!">/tmp/postfix_down; mail -s "postfix-down(IP)" -c $mailer2 $mailer < /tmp/postfix_down; service postfix start; fi#Mysql 的状态检查,看是否存在mysql?存在则发邮件报告正常,否则就重启服务 mysql=`ps aux |grep mysql |grep -v "grep" |awk {'print $1'} |grep mysql` if [ "$mysql" == "mysql" ]; then echo "$dt <$host> mysql is ok! " >/tmp/mysql_ok; mail -s "mysql-OK(IP)" $mailer < /tmp/mysql_ok; else echo "$dt <$host> mysql is down! will start!" > /tmp/mysql_down; mail -s "mysql-down(IP)" -c $mailer2 $mailer < /tmp/mysql_down; service mysqld start; fi将上述保存成可执行的文件,添加cron计划任务中,每10分钟运行一次
本文转自andylhz 51CTO博客,原文链接:http://blog.51cto.com/andylhz2009/494420,如需转载请自行联系原作者