HOST:{HOST.NAME} {HOST.IP} TIME:{EVENT.DATE} {EVENT.TIME} LEVEL:{TRIGGER.SEVERITY} NAME:{TRIGGER.NAME} messages:{ITEM.NAME}:{ITEM.VALUE} ID:{EVENT.ID}
HOST:{HOST.NAME} {HOST.IP} TIME:{EVENT.DATE} {EVENT.TIME} LEVEL:{TRIGGER.SEVERITY} NAME:{TRIGGER.NAME} messages:{ITEM.NAME}:{ITEM.VALUE} ID:{EVENT.ID}
A机器 [root@hf-01 ~]# vim /etc/zabbix/zabbix_server.conf 搜索 /alert AlertScriptsPath=/usr/lib/zabbix/alertscripts #报警脚本所在路径
A机器 [root@hf-01 ~]# vim /usr/lib/zabbix/alertscripts/mail.py #!/usr/bin/env python #-*- coding: UTF-8 -*- import os,sys reload(sys) sys.setdefaultencoding('utf8') import getopt import smtplib from email.MIMEText import MIMEText from email.MIMEMultipart import MIMEMultipart from subprocess import * def sendqqmail(username,password,mailfrom,mailto,subject,content): gserver = 'smtp.163.com' ##定义发邮件类型 gport = 25 try: msg = MIMEText(unicode(content).encode('utf-8')) msg['from'] = mailfrom msg['to'] = mailto msg['Reply-To'] = mailfrom msg['Subject'] = subject smtp = smtplib.SMTP(gserver, gport) smtp.set_debuglevel(0) smtp.ehlo() smtp.login(username,password) smtp.sendmail(mailfrom, mailto, msg.as_string()) smtp.close() except Exception,err: print "Send mail failed. Error: %s" % err def main(): to=sys.argv[1] subject=sys.argv[2] content=sys.argv[3] ##定义QQ邮箱的帐号和密码,你须要修改为你本身的帐号和密码(请不要把真实的用户名和密码放到网上公开,不然你会死的很惨) sendqqmail('163邮箱','密码','163邮箱',to,subject,content) if __name__ == "__main__": main() #####脚本使用说明###### #1. 首先定义好脚本中的邮箱帐号和密码 #2. 脚本执行命令为:python mail.py 目标邮箱 "邮件主题" "邮件内容" 保存退出
[root@hf-01 ~]# chmod 755 /usr/lib/zabbix/alertscripts/mail.py [root@hf-01 ~]#
[root@hf-01 ~]# cd /usr/lib/zabbix/alertscripts/ [root@hf-01 alertscripts]# python mail.py han1118feng@163.com "ssss" "dddd" [root@hf-01 alertscripts]#
[root@hf-01 alertscripts]# python mail.py han1118feng@163.com "邮件" "dddd" [root@hf-01 alertscripts]#
默认信息定义当发生报警时,zabbix会向你的邮箱发送什么内容 HOST:{HOST.NAME} {HOST.IP} (定义主机名) TIME:{EVENT.DATE} {EVENT.TIME} (定义事件发生时间) LEVEL:{TRIGGER.SEVERITY} (定义示警度) NAME:{TRIGGER.NAME} (定义哪个触发器发出的报警) messages:{ITEM.NAME}:{ITEM.VALUE} (发出告警会出现什么状态码) ID:{EVENT.ID} (发生事件的id)
HOST:{HOST.NAME} {HOST.IP} TIME:{EVENT.DATE} {EVENT.TIME} LEVEL:{TRIGGER.SEVERITY} NAME:{TRIGGER.NAME} messages:{ITEM.NAME}:{ITEM.VALUE} ID:{EVENT.ID}