当前公司nagios已经正常使用,也能报警,但是邮件报警采用的是sendmail,发件人总是nagios@localhost,收到后经常被加入到邮件中的垃圾箱,并且有些邮箱服务器有反垃圾检测,导致用户接收不到邮件。为解决这个问题,决定自己写一个邮件发送程序。
相关阅读:
在RHEL5.3上配置基本的Nagios系统(使用Nagios-3.1.2)
CentOS 5.5+Nginx+Nagios监控端和被控端安装配置指南
Ubuntu 13.10 Server 安装 Nagios Core 网络监控运用
过程如下:
1、开发发送邮件脚本
[root@yckj python]# cat sendmail.py
#!/usr/bin/python
# -*- coding:utf-8 -*-
import smtplib
import sys
from email.mime.text import MIMEText
import time
#获取当前时间
current_time=time.strftime('%Y-%m-%d %H:%M',time.localtime(time.time()))
#获取用户名密码登陆远程再也箱服务器
mail_host = 'smtp.exmail.qq.com'
mail_user = 'yangr@linuxidc.com'
mail_pwd = '12345'
#此处密码为假
def send_email( content, mailto, get_sub ):
#获取邮件内容,后面是为了支持中文
msg = MIMEText( content,_subtype='plain',_charset='gb2312')
#获取收件人,与标题
msg['From'] = mail_user
msg['Subject'] =get_sub
msg['To'] = ",".join( mailto )
try:
#连接上远程邮件发送服务器
s = smtplib.SMTP_SSL( mail_host, 465 )
#登陆
s.login(mail_user, mail_pwd )
#发送邮件
s.sendmail(mail_user, mailto, msg.as_string())
s.close()
except Exception as e:
print 'Exception: ', e
#传参第一个为邮件标题
title=sys.argv[1]
#传参第二个为邮件内容,此处定义内容格式
cont="""
----------------------------------
| 云巢运维管理平台
----------------------------------
| 报警信息: %s
----------------------------------
| 发送时间: %s
----------------------------------
""" %(sys.argv[2],current_time)
#指定收件人
to_list = [
#'zhengzh@linuxidc.com',
#'duc@linuxidc.com',
#'yangr@linuxidc.com',
'yangy@linuxidc.com',
]
#执行上述类
send_email( cont, to_list, title)
2、定义Nagios执行发送邮件的命令
编辑nagios定义命令的文件,注销掉原有的发送邮件命令。新增如下:
#vi /usr/local/nagios/etc/objects/commands.cfg
define command{
command_name notify-host-by-email
command_line /usr/bin/python/python/sendmail.py "$HOSTNAME$_$HOSTADDRESS$ $NOTIFICATIONTYPE$, $HOSTNAME$ is $HOSTSTATE$" "$HOSTNAME$ $HOSTADDRESS$ is$HOSTSTATE$,$HOSTOUTPUT$."
}
define command{
command_name notify-service-by-email
command_line /usr/bin/python/python/sendmail.py "$HOSTNAME$_$HOSTADDRESS$ service is $SERVICESTATE$" "$HOSTALIAS$_$HOSTADDRESS$state is $SERVICESTATE$,$SERVICEOUTPUT$. "
#执行这个程序,把主机名报警信息传参进去就可。
}
重启nagios
#/etc/init.d/nagios chekconfig
#/etc/init.d/nagios restart
3、邮件报警现象
Down了nagios监控中的一台192.167.6.136,报警信息如下:
注:模板内容可自行更改。