zabbix实现邮件报警
Posted Jack秦
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了zabbix实现邮件报警相关的知识,希望对你有一定的参考价值。
说明:
zabbix服务端配置文件主要参数
LogFile=/tmp/zabbix_server.log
DBName=zabbix #zabbix的密码
DBUser=root #用来连接mysql的用户名
DBPassword= #密码
DBHost=127.0.0.1 #本机
DBSocket=/data/mysql_3306/var/mysql_3306.sock #mysql的sock端口
ListenIP=127.0.0.1
date.timezone = "Asia/Shanghai"
Zabbix监控服务端、客户端都已经部署完成,被监控主机已经添加,Zabiix监控运行正常。
实现目的:
在Zabbix服务端设置邮件报警,当被监控主机宕机或者达到触发器预设值时,会自动发送报警邮件到指定邮箱。
具体操作:
以下操作在Zabbix监控服务端进行
备注:Zabbix监控服务端
操作系统:CentOS
使用外部邮箱账号发送报警邮件设置:
一、关闭sendmail或者postfix
service sendmail stop #关闭
chkconfig sendmail off #禁止开机启动
service postfix stop
chkconfig postfix off
备注:
使用外部邮箱账号时,不需要启动sendmail或者postfix
如果在sendmail或者postfix启动的同时使用外部邮箱发送报警邮件,首先会读取外部邮箱
配置信息。
二、安装邮件发送工具mailx
yum install mailx #安装
CentOS 5.x 编译安装mailx,直接yum安装的mailx版本太旧,使用外部邮件发送会有问题。
yum remove mailx #卸载系统自带的旧版mailx
下载mailx:
http://nchc.dl.sourceforge.net/project/heirloom/heirloom-mailx/12.4/mailx-12.4.tar.bz2
tar jxvf mailx-12.4.tar.bz2 #解压
cd mailx-12.4 #进入目录
make #编译
原来差补丁,修复他
[root@localhost mailx-12.4]
# wget http://www.linuxfromscratch.org/patches/blfs/7.6/mailx-12.4-openssl_1.0.0_build_fix-1.patch
[root@localhost mailx-12.4]
# patch -Np1 -i mailx-12.4-openssl_1.0.0_build_fix-1.patch
patching
file
makeconfig
patching
file
openssl.c
[root@localhost mailx-12.4]
# make clean #清除历史编译后文件
make install UCBINSTALL=/usr/bin/install #安装
ln -s /usr/local/bin/mailx /bin/mail #创建mailx到mail的软连接
ln -s /etc/nail.rc /etc/mail.rc #创建mailx配置文件软连接
三、配置Zabbix服务端外部邮箱
vi /etc/mail.rc #编辑,添加以下信息
set from=xxx@163.com
set smtp=smtp.163.com //添加发送人、发送服务器
set smtp-auth-user=xxx@163.com
set smtp-auth-password=123456 //添加发送人的邮箱和登录密码。
set smtp-auth=login
:wq! #保存退出
echo "zabbix test mail" |mail -s "zabbix" yyy@163.com
#测试发送邮件,标题zabbix,邮件内容:zabbix test mail,发送到的邮箱:yyy@163.com或者zzz@139.com,发送短信的时候要在139邮箱上面开启短信提醒。这里我就不说了,自己百度去。
#这时候,邮箱yyy@163.com会收到来自xxx@163.com的测试邮件
四、配置Zabbix服务端邮件报警
1、打开Zabbix
管理-示警媒介类型-创建媒体类型
名称:Sendmail
类型:脚本
脚本名称:sendmail.sh
已启用:勾选
2、设置Zabbix用户报警邮箱地址
可以添加163邮箱也可以添加139邮箱。
类型:Sendmail
收件人:xxx@163.com
其他默认即可,也可
以根据需要设置
状态:已启用
存档
3、设置Zabbix触发报警的动作
组态-动作-创建动作
名称:Action-Email
默认接收人:故障{TRIGGER.STATUS},服务器:{HOSTNAME1}发生: {TRIGGER.NAME}故障!
默认信息:
告警主机:{HOSTNAME1}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警项目:{TRIGGER.KEY1}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID:{EVENT.ID}
恢复信息:打钩
恢复主旨:恢复{TRIGGER.STATUS}, 服务器:{HOSTNAME1}: {TRIGGER.NAME}已恢复!
恢复信息:
告警主机:{HOSTNAME1}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警项目:{TRIGGER.KEY1}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE1}
事件ID:{EVENT.ID}
已启用:打钩
切换到操作选项
新的
操作类型:送出信息
送到用户:添加
默认信息:打钩
选择用户:Admin
选择
仅送到:Sendmail
存档
4、添加Zabbix服务端邮件发送脚本
cd /usr/local/zabbix/share/zabbix/alertscripts #进入脚本存放目录
vi sendmail.sh #编辑,添加以下代码
#!/bin/sh
echo "$3" | mail -s "$2" $1
:wq! #保存退出
chown -R zabbix.zabbix /usr/local/zabbix/share/zabbix/alertscripts/*
zabbix_server.conf 文件中加入脚本的相对路径
AlertScriptsPath=/usr/local/zabbix/share/zabbix/alertscripts
#设置脚本所有者为zabbix用户
chmod +x /usr/local/zabbix/share/zabbix/alertscripts/sendmail.sh
#设置脚本执行权限
五、测试Zabbix报警
关闭Zabbix客户端服务
service zabbix_agentd stop
查看你的xxx@163.com邮箱,会收到报警邮件
再开启Zabbix客户端服务
service zabbix_agentd start
查看你的xxx@163.com邮箱,会收到恢复邮件
使用外部邮箱账号发送报警邮件设置完成。
至此,Zabbix邮件报警设置完成。
阿里云不让自建邮箱,是为了防止邮件乱发,又不发溯源
所有25端口全部被封
改用465端口
我选得163邮箱,建一个设置个复杂密码一辈子不登陆了
上去设置里开启 SMTP pop 什么的都点开
网上搜了搜,没发现能成功测试的,都有一点报错
下面我的版本,贴出来,大家用吧
遇到的报错:"/root/dead.letter" 311/19508
553 Mail from must equal authorized user
反正挺恶心,2天才搞定
然后安装mailx
yum install mailx
vi /etc/mail.rc
添加下面这些
set smtp="smtps://smtp.163.com:465"
set from="1111111111@163.com"
set smtp-auth=login
set smtp-auth-user="11111111@163.com"
set smtp-auth-password="111111111"
set ssl-verify=ignore
set nss-config-dir=/etc/pki/nssdb
测试
cat /opt/1111 | mailx -v -s \'biaoti\' \'1111111111111@qq.com\'
以上是关于zabbix实现邮件报警的主要内容,如果未能解决你的问题,请参考以下文章