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

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: itnihao@qq.com

#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 = 'itnihao_zabbix@itnihao.com'

#smtp_pass = '1234567890'

#163 Mail

#smtp_server = 'smtp.163.com'

#smtp_port = 25

#smtp_user = 'itnihao_zabbix@163.com'

#smtp_pass = '1234567890'

#QQ Mail

smtp_server ='smtp.qq.com'

smtp_port = 25

smtp_user   ='itnihao_zabbix@qq.com'

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 


1 条评论

  1. nier说道:

    💡

发表评论

登录 后发表评论.