分布式监控系统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 ),"\r\n") 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 + "\r\n" + "\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即可!