分布式监控系统Zabbix-3.0.3-完整安装记录(5)-邮件报警部署

时间:2022-04-23
本文章向大家介绍分布式监控系统Zabbix-3.0.3-完整安装记录(5)-邮件报警部署,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

前面几篇陆续介绍了zabbix3.0.3监控系统的部署和监控项配置,今天这里分享下zabbix3.0.3的邮件报警的配置过程~ 由于采用sendmail发送邮件,常常会被认为是垃圾邮件被拒,所以不推荐这种方式! 这里,针对zabbix报警信息的发送,可以采用下面两种方式中的任意一种: 1)利用sendEmail程序来发送报警邮件.sendEmail是一个轻量级,命令行的SMTP邮件客户端,非常完美,使用简单并且功能强大.这个被设计用在php、bash 、perl和web站点使用。 2)利用python脚本来发送邮件

一、利用sendemail发送报警邮件 1)先下载安装包到本地,解压。 [root@Zabbix-server ~]# cd /usr/local/src/ [root@Zabbix-server src]# wget -c http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz [root@Zabbix-server src]# tar -zvxf sendEmail-v1.56.tar.gz [root@Zabbix-server src]# cd sendEmail-v1.56 [root@Zabbix-server sendEmail-v1.56]# cp -a sendEmail /usr/local/bin/ [root@Zabbix-server sendEmail-v1.56]# chmod +x /usr/local/bin/sendEmail [root@Zabbix-server sendEmail-v1.56]# file /usr/local/bin/sendEmail /usr/local/bin/sendEmail: a /usr/bin/perl -w script text executable

#查看sendemail的帮助信息 [root@Zabbix-server src]# cd sendEmail-v1.56 [root@Zabbix-server sendEmail-v1.56]# /usr/local/bin/sendEmail

sendEmail-1.56 by Brandon Zehm <caspian@dotconf.net>

Synopsis: sendEmail -f ADDRESS [options]

Required: -f ADDRESS from (sender) email address * At least one recipient required via -t, -cc, or -bcc * Message body required via -m, STDIN, or -o message-file=FILE

Common: -t ADDRESS [ADDR ...] to email address(es) -u SUBJECT message subject -m MESSAGE message body -s SERVER[:PORT] smtp mail relay, default is localhost:25

Optional: -a FILE [FILE ...] file attachment(s) -cc ADDRESS [ADDR ...] cc email address(es) -bcc ADDRESS [ADDR ...] bcc email address(es) -xu USERNAME username for SMTP authentication -xp PASSWORD password for SMTP authentication

Paranormal: -b BINDADDR[:PORT] local host bind address -l LOGFILE log to the specified file -v verbosity, use multiple times for greater effect -q be quiet (i.e. no STDOUT output) -o NAME=VALUE advanced options, for details try: --help misc -o message-content-type=<auto|text|html> -o message-file=FILE -o message-format=raw -o message-header=HEADER -o message-charset=CHARSET -o reply-to=ADDRESS -o timeout=SECONDS -o username=USERNAME -o password=PASSWORD -o tls=<auto|yes|no> -o fqdn=FQDN

Help: --help the helpful overview you're reading now --help addressing explain addressing and related options --help message explain message body input and related options --help networking explain -s, -b, etc --help output explain logging and other output options --help misc explain -o options, TLS, SMTP auth, and more

2)安装下依赖 [root@Zabbix-server sendEmail-v1.56]# yum install perl-Net-SSLeay perl-IO-Socket-SSL -y

[root@Zabbix-server sendEmail-v1.56]# /usr/local/bin/sendEmail -f from@huanqiu.cn -t to@huanqiu.cn -s smtp.huanqiu.cn -u "我是邮件主题" -o message-content-type=html -o message-charset=utf8 -xu from@huanqiu.cn -xp WEE78@12l$ -m "我是邮件内容"

命令说明: /usr/local/bin/sendEmail                     #命令主程序 -f from@uhanqiu.cn                          #发件人邮箱 -t to@huanqiu.cn                              #收件人邮箱 -s smtp.huanqi.cn                            #发件人邮箱的smtp服务器 -u "我是邮件主题"                               #邮件的标题 -o message-content-type=html          #邮件内容的格式,html表示它是html格式 -o message-charset=utf8                   #邮件内容编码 -xu from@huanqiu.cn                       #发件人邮箱的用户名 -xp WEE78@12l$                             #发件人邮箱密码 -m "我是邮件内容"                             #邮件的具体内容

例如: [root@Zabbix-server alertscripts]# /usr/local/bin/sendEmail -f ops@huanqiu.cn -t wangshibo@huanqiu.cn -s smtp.huanqiu.cn -u "我是邮件主题" -o message-content-type=html -o message-charset=utf8 -xu ops@huanqiu.cn -xp WEE78@12l$ -m "我是邮件内容"

Oct 14 19:38:29 zabbix-server sendEmail[65454]: Email was sent successfully! [root@Zabbix-server alertscripts]#

登陆wangshibo@huanqiu.cn邮箱,发现已经收到了上面发送的邮件:

3)下面开始设置zabbix的sendemail邮件发送脚本

进入zabbix自定义的指定目录,我这里是/usr/local/zabbix 可以查看zabbix_server.conf配置文件AlertScriptsPath变量是如何定义的。 找到AlertScriptsPath选项,可以自定义位置 [root@Zabbix-server sendEmail-v1.56]# cat /usr/local/zabbix/etc/zabbix_server.conf ....... ### Option: AlertScriptsPath # Full path to location of custom alert scripts. # Default depends on compilation options. # # Mandatory: no # Default: # AlertScriptsPath=${datadir}/zabbix/alertscripts

AlertScriptsPath=/usr/local/zabbix/alertscripts

[root@Zabbix-server sendEmail-v1.56]# cd /usr/local/zabbix/alertscripts/

下面是sendemail的邮件发送脚本(这个脚本通用,确保了zabbix邮件报警信息不会出现中文乱码)

--------------------------------------------------------------------- 下面我用的是阿里的企业邮件,smtp地址是smtp@huanqiu.cn 如果用163邮箱,smtp地址是smtp.163.com 如果是腾讯企业邮箱,smtp是smtp.exmail.qq.com --------------------------------------------------------------------

[root@Zabbix-server alertscripts]# cat mail.sh #!/bin/bash # # Filename: SendEmail.sh # Revision: 1.0 # Date: 2014/07/04 # Author: Qicheng # Email: # Website: http://www.cnblogs.com/kevingrace/ # Description: zabbix邮件告警脚本 # Notes: 使用sendEmail # # 脚本的日志文件 LOGFILE="/tmp/Email.log" :>"$LOGFILE" exec 1>"$LOGFILE" exec 2>&1 SMTP_server='smtp.huanqiu.cn'                            #SMTP服务器,变量值需要自行修改 username='ops@huanqiu.cn'                                 #用户名,变量值需要自行修改 password='WEE78@12l$'                                     #密码,变量值需要自行修改 from_email_address='ops@huanqiu.cn'                  #发件人Email地址,变量值需要自行修改 to_email_address="$1"                                        #收件人Email地址,zabbix传入的第一个参数 message_subject_utf8="$2"                               #邮件标题,zabbix传入的第二个参数 message_body_utf8="$3"                                    #邮件内容,zabbix传入的第三个参数 # 转换邮件标题为GB2312,解决邮件标题含有中文,收到邮件显示乱码的问题。 message_subject_gb2312=`iconv -t GB2312 -f UTF-8 << EOF $message_subject_utf8 EOF` [ $? -eq 0 ] && message_subject="$message_subject_gb2312" || message_subject="$message_subject_utf8" # 转换邮件内容为GB2312,解决收到邮件内容乱码 message_body_gb2312=`iconv -t GB2312 -f UTF-8 << EOF $message_body_utf8 EOF` [ $? -eq 0 ] && message_body="$message_body_gb2312" || message_body="$message_body_utf8" # 发送邮件 sendEmail='/usr/local/bin/sendEmail' set -x $sendEmail -s "$SMTP_server" -xu "$username" -xp "$password" -f "$from_email_address" -t "$to_email_address" -u "$message_subject" -m "$message_body" -o message-content-type=text -o message-charset=gb2312

[root@Zabbix-server alertscripts]# chmod 755 mail.sh [root@Zabbix-server alertscripts]# touch /tmp/Email.log [root@Zabbix-server alertscripts]# chown zabbix.zabbix /tmp/Email.log [root@Zabbix-server alertscripts]# chown zabbix.zabbix mail.sh

测试脚本发送邮件 [root@Zabbix-server alertscripts]# ./mail.sh wangshibo@huanqiu.cn 主题 测试 [root@Zabbix-server alertscripts]# 登陆wangshibo@huanqiu.cn邮箱,发现已经收到了上面发送的邮件:

4)接着,登陆zabbix界面,进行设置 注意:zabbix 3.0 需要在为alert脚本定义参数,以前的版本参数都固定的,现在用户可以自己定义命令行的参数了。添加的参数也就是脚本中的$1、$2、$3等。

点击"管理"->"报警媒介类型"->点击最右边的"创建媒体类型" 

输入上面在alertscripts目录下创建的脚本名称mail.sh,类型选择脚本并添加以下3个参数, 分别对应sendEmail.sh脚本需要的3个参数:收件人地址、主题、详细内容 {ALERT.SENDTO} {ALERT.SUBJECT} {ALERT.MESSAGE}

这里注意一下: 安装zabbix 3.0之后,写的脚本一直发信不成功,手动执行时可以的。 那是因为zabbix3.0之后,可以自定义参数了。所以不写参数,它是不会传参数的。 在2.x版本不存在这个问题,默认会传3个参数。

点击“管理”->“用户"->"zabbix"  (我这里的zabbix的管理员账号是zabbix)

上面添加的是发送给wangshibo@huanqiu.cn的报警设置,显示如下:

如果是发送给多人,那么需要”添加“多个邮箱账号!

点击“管理”->“用户群组”,点击zabbix administrator后面的调用模式。

点击用户群组Zabbix administrators的”权限“,点击”添加“,选择所有权限 ,最后点击下面的”更新“

点击“配置”->“动作”,这里可以点击右边的“创建动作”(事件源是”触发器“,也就是Triggers),也可以直接使用默认动作进行修改 这里我选择修改默认的Report problems to Zabbix administrators

 修改动作名称为”zabbix报警“。

注意: zabbix默认的告警内容不丰富,信息不足,我做了如下的调整(默认信息和恢复信息是一致的): 告警主机:{HOST.NAME} 主机IP: {HOST.IP} 告警时间:{EVENT.DATE} {EVENT.TIME} 告警等级:{TRIGGER.SEVERITY} 告警信息:{TRIGGER.NAME} 问题详情:{ITEM.NAME}:{ITEM.VALUE} 当前状态: {TRIGGER.STATUS}:{ITEM.VALUE1} 事件ID: {EVENT.ID}

--------------------------------------------------------------------------------------------------------------------------- 如上,在“配置”->“动作”里的“条件”里的设置 1)计算方式 设置为“与/或”,说明只要触发其中任何一个都会发报警邮件 2)条件: 上面默认设置的是下面两个: A:维护状态 非在 维护 B:触发器值 = 问题

按照上面的设置后,当被监控主机宕机或zabbix_agent(10050端口)关闭后,就会发生报警~

但是这些远远不能满足我们的运维监控需求。 比如当被监控主机的根磁盘爆满时,需要发送报警邮件!这就需要额外添加上面“动作”里的“条件”设置

如在“条件”里追加“主机”和“模板”,将所监控的主机和被监控主机采用的模板都选上为触发条件

这样,当任何一个条件被触发时,都会发送报警邮件!

------------------------------------------------------------------------------------------------------------------------------------------------------------

设置“操作”,可以点击”新的“添加操作规则,也可以直接修改已有的操作规则:

默认的步骤是1-3,也即是从1开始到3结束。一旦故障发生,就是执行sendEmail.sh脚本发生报警邮件给zabbix用户和zabbix administrator组。 假如故障持续了1个小时,它也只发送3次,第1-3次(即前3次)邮箱发送给zabbix用户,时间间隔为0秒。 如果改成1-0,0是表示不限制.无限发送 间隔就是默认持续时间60秒。那么一个小时,就会发送60封邮件。 如果需要短信报警的话,可以再创建一条新的动作,选择短信脚本。

------------------------------------------------------------- 也可以在添加新的”操作“,比如上面前3次报警发送给zabbix。 还可以再设置第30-35次报警(也就是报警事故已经发生30秒之后)发送给另外的用户 这样,就创建了两个"操作",上面我只创建了一个操作 -------------------------------------------------------------

这样,zabbix利用sendemail发送报警信息的设置就已经完成了!

测试:

将192.168.1.19服务器的zabbix_agent进程关闭。

发现可以正常收到故障报警邮件(收到3次邮件PROBLEM故障邮件):

待192.168.1.19服务器的zabbix_agent进程恢复后,也有报警邮件(收到1次OK(恢复状态)的邮件)。

最后,点击”报表“->”动作日志“,可以看到触发动作的次数(右边还看查看到邮件发送状态“已发送”)。 故障报警只会有3次,除非test主机状态改变,也就是正常恢复的时候,才会再触发一次,否则不会再触发。

 ------------------------------------------------------------------------------------------------------------------------------------------------------------

以上是zabbix利用sendemail发送报警邮件的配置。 下面介绍下利用python脚本发送报警邮件的配置!

首先是创建python脚本zabbix_sendemail.py,如下: [root@Zabbix-server alertscripts]# pwd /usr/local/zabbix/alertscripts

[root@Zabbix-server alertscripts]# cat zabbix_sendemail.py

#!/usr/bin/env python
# -*- coding: utf-8 -*-
import pdb
import smtplib
import string
import time
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
#pdb.set_trace()
#HOST = "mail.gw.com.cn"
def S_Mail():
    HOST = "smtp.huanqiu.cn"                           
    SUBJECT = sys.argv[2].decode('utf-8').encode('gbk')   
    TO =sys.argv[1]                                       
    FROM = "ops@huanqiu.cn"
    text = sys.argv[3].decode('utf-8').encode('gbk')      
    BODY = string.join((
                    "FROM: %s" % FROM,
                    "To: %s"  % TO,
                    "Subject: %s" %SUBJECT,
                    "",
                    text
                    ),"rn")
    server = smtplib.SMTP()
    server.connect(HOST,25)
    #server.starttls()
    server.login("ops@huanqiu.cn","WEE78@12l$")
    server.sendmail(FROM,[TO],BODY)
    server.quit()
# email log 记录日志
    with open('/data/logs/zabbix/Email.log','a') as f:
        date=time.strftime("%y-%m-%d %H:%M:%S")
        str = date + "    " + TO +"    " + SUBJECT + "rn" + "n"
        str1 = str.decode('gbk').encode('utf-8')
#       print("%s" %str1)
        f.write(str1)
if __name__=='__main__':
    S_Mail()

[root@Zabbix-server alertscripts]# mkdir -p /data/logs/zabbix/

测试邮件发送: [root@Zabbix-server alertscripts]# ./zabbix_sendemail.py wangshibo@huanqiu.cn 主题 测试 [root@Zabbix-server alertscripts]#

然后登陆wangshibo@huanqiu.cn邮箱,发现已经收到邮件了。如下:

其他zabbix界面上的配置和上面差不多,只需要将mail.sh改为zabbix_sendemail.py即可!