Zabbix3.0.2使用外部python脚本实现邮件报警,zabbix3.0.2python,1,找到默认存放脚本


1,找到默认存放脚本的路径(我是在默认路径下面放着,如果想换别的路径,修改zabbix_server.conf配置文件)

/usr/local/zabbix-server/share/zabbix/alertscripts 脚本存放路径

2,在目录新建一个mail.py的文件,脚本参考:

cd /usr/local/zabbix-server/share/zabbix/alertscripts

vim mail.py

#!/usr/bin/python

#coding:utf-8

#author: itnihao

#mail: [email protected]

#url:https://github.com/itnihao/zabbix-book/edit/master/06-chapter/zabbix_sendmail_v2.py 脚本直接down修改下复制会出现格式问题~

import smtplib

from email.mime.text import MIMEText

import os

import argparse

import logging

import datetime

#QQ enterprise

#smtp_server = ‘smtp.exmail.qq.com‘

#smtp_port = 25

#smtp_user = ‘[email protected]‘

#smtp_pass = ‘1234567890‘

#163 Mail

#smtp_server = ‘smtp.163.com‘

#smtp_port = 25

#smtp_user = ‘[email protected]‘

#smtp_pass = ‘1234567890‘

#QQ Mail

smtp_server =‘smtp.qq.com‘

smtp_port = 25

smtp_user =‘[email protected]‘

smtp_pass =‘1234567890‘

def send_mail(mail_to,subject,content):

msg = MIMEText(content,_subtype=‘plain‘, _charset=‘utf-8‘)

msg[‘Subject‘] = unicode(subject,‘UTF-8‘)

msg[‘From‘] = smtp_user

msg[‘to‘] = mail_to

global sendstatus

global senderr

try:

if smtp_port == 465:

smtp = smtplib.SMTP_SSL()

else:

smtp = smtplib.SMTP()

smtp.connect(smtp_server,smtp_port)

smtp.login(smtp_user,smtp_pass)

smtp.sendmail(smtp_user,mail_to,msg.as_string())

smtp.close()

print ‘send ok‘

sendstatus = True

except Exception,e:

senderr=str(e)

print senderr

sendstatus = False

def logwrite(sendstatus,mail_to,content):

logpath=‘/var/log/zabbix/alert‘

if not sendstatus:

content = senderr

if not os.path.isdir(logpath):

os.makedirs(logpath)

t=datetime.datetime.now()

daytime=t.strftime(‘%Y-%m-%d‘)

daylogfile=logpath+‘/‘+str(daytime)+‘.log‘

logging.basicConfig(filename=daylogfile,level=logging.DEBUG)

os.system(‘chown zabbix.zabbix {0}‘.format(daylogfile))

logging.info(‘*‘*130)

logging.debug(str(t)+‘ mail send to {0},content is :\n {1}‘.format(mail_to,content))

if __name__ == "__main__":

parser = argparse.ArgumentParser(description=‘Send mail to user for zabbix alerting‘)

parser.add_argument(‘mail_to‘,action="store", help=‘The address of the E-mail that send to user ‘)

parser.add_argument(‘subject‘,action="store", help=‘The subject of the E-mail‘)

parser.add_argument(‘content‘,action="store", help=‘The content of the E-mail‘)

args = parser.parse_args()

mail_to=args.mail_to

subject=args.subject

content=args.content

send_mail(mail_to,subject,content)

logwrite(sendstatus,mail_to,content)

3,修改脚本的权限

# chown zabbix.zabbix mail.py

# chmod 775 mail.py

4,zabbix web配置

在配置媒介类型选择,创建一个媒介类型

技术分享

填写下面信息,类型选择脚本,需要填写zabbix3.0需要下面3个参数。

技术分享

创建用户或者在admin用户里设置报警

技术分享

此处添加的是出现故障后邮件通知到的邮件,也就是收件人。

技术分享

创建一个action,实现邮件报警,在配置-Action-create action里

(处我图片和下面给的模板不一样,建议使用模板,因为我使用的服务器不在中国区域,所有邮件标题会乱码.. 所以此图我把标题改短了。)

技术分享

Name

Action-Email

Default subject

故障{TRIGGER.STATUS},服务器:{HOSTNAME1}发生: {TRIGGER.NAME}故障!

Default message

告警主机:{HOSTNAME1}

告警时间:{EVENT.DATE} {EVENT.TIME}

告警等级:{TRIGGER.SEVERITY}

告警信息: {TRIGGER.NAME}

告警项目:{TRIGGER.KEY1}

问题详情:{ITEM.NAME}:{ITEM.VALUE}

当前状态:{TRIGGER.STATUS}:{ITEM.VALUE1}

事件ID:{EVENT.ID}

请至Montoring-Events中查看详细情况。

Recovery subject

恢复{TRIGGER.STATUS}, 服务器:{HOSTNAME1}: {TRIGGER.NAME}已恢复!

Recovery message

告警主机:{HOSTNAME1}

告警时间:{EVENT.DATE} {EVENT.TIME}

告警等级:{TRIGGER.SEVERITY}

告警信息: {TRIGGER.NAME}

告警项目:{TRIGGER.KEY1}

问题详情:{ITEM.NAME}:{ITEM.VALUE}

当前状态:{TRIGGER.STATUS}:{ITEM.VALUE1}

事件ID:{EVENT.ID}

报警已恢复,请放松心情。

技术分享

此处要注意操作类型,发送消息,还有消息的脚本。都要选对.

技术分享

5,测试zabbix发送邮件

找一个agent客户端,停掉。然后看报警邮件~

Kill掉之后,可以在发送这里看到已经发生成功~

注意:zabbix的报警一般是5分钟发一次。比如:16:20停止的,16:25才会收到故障邮件,16:30处理了。16:35可以收到恢复信息~ …

技术分享

技术分享

6.总结

我此处使用的ubuntu 16.4的系统,开始尝用mailx发,后来少一些库文件无法安装,后来切换其他办法都已收不到邮件最后才选定用外部python脚本来实现~·ubuntu系统有很多软件的依赖环境不自带.apt-get实在用的不顺手,使用126邮箱出现客户端授权码无法无法在python脚本中登陆.QQ邮箱只能发生给自己. 最后选的是公司的企业邮箱。但是由于zabbix会频繁的发送邮件很多也被丢进垃圾箱… 最后在企业邮箱做的转发到QQ邮箱。

Ubuntu用开发和学习没问题,但是用作服务器问题还不少.

正确的姿势: centos+zabbix+企业邮箱 后续如果有机会写下篇zabbix中微信报警。

参考文章:

https://github.com/itnihao/zabbix-book/edit/master/06-chapter/zabbix_sendmail_v2.py


本文出自 “Internet&Linux” 博客,请务必保留此出处http://linuxsec.blog.51cto.com/10240211/1909502

Zabbix3.0.2使用外部python脚本实现邮件报警

评论关闭