Linux(centos6)环境zabbix 3.4邮件报警配置及zabbix故障处理
本片博客主要介绍了 Centos 6下 Zabbix 3.4邮件报警配置及Zabbix邮件故障解决方法 ;分别介绍了zabbix使用本地账号发送邮件报警及使用互联网账号发送邮件报警配置,并处理邮件发送故障“cannot connect to SMTP server "zabbix.itwish.cn": cannot connect to [:25]: Connection refused”及“Support for SMTP authentication was not compiled in”。Zabbix Server报警
说明:
Zabbix监控服务端、客户端都已经部署完成,被监控主机已经添加,Zabiix监控运行正常。Zabbix配置监控方式请参照前文:http://blog.运维网.com/itwish/2288052
实现:
在Zabbix服务端设置邮件报警,当被监控主机宕机或者达到触发器预设值时,会自动发送报警邮件到指定邮箱。
[*]Zabbix服务端只是单纯的发送报警邮件到指定邮箱,发送报警邮件的这个邮箱账号是Zabbix服务端的本地邮箱账号,只能发送,不能接收外部邮件。
[*]使用互联网上可正常收发邮件的邮箱账号(例如:xxx@qq.com),通过在Zabbix服务端中设置,使其能够发送报警邮件到指定邮箱。
Zabbix 使用本地账号发送邮件报警配置
一、安装邮件服务poxfix
# yum install postfix # 安装postfix
# service postfix start # 启动postfix服务
# chkconfig postfix on # 开机自启动
# ss -tunl # SMTP 25端口启用
NetidState Recv-Q Send-Q Local Address:Port Peer Address:Port
...
tcp LISTEN 0 100 ::1:25 :::*
tcp LISTEN 0 100 127.0.0.1:25 *:*二、安装邮件发送工具mailx
# yum install mailx # 安装邮件发送工具
# echo "Hello word" | mailx -s "hello" 345876547@qq.com # 测试发送邮件
注:
mailx是UNIX系统上用来处理邮件的工具,使用它可以发送,读取邮件。
发送格式:
mailx -s subject XXX@163.com < message_file
假设邮件内容存储于msg文件中,用如下方法:
mailx -s "test mail" XXX@163.com < msg
或者
cat msg | mailx -s "test mail" XXX@163.com
多个收件人之间用逗号分隔
cat msg | mailx -s "test mail" XXX@163.com,XX2@163.com
也可以直接从命令行输入邮件内容:
mailx -s "test" XXX@163.com
上面这条命令会进入命令行输入状态,此时可以输入内容,按Ctrl+d键来结束输入。三、配置zabbix邮件报警
[*] 报警介质类型配置:登陆web管理界面,进入“管理”——“报警媒介类型”——“Email”选项
名称: Email
SMTP服务器: zabbix.itwish.cn (为zabbix主机名称)
SMTP服务器端口: 25
SMTP HELO: itwish.cn
SMTP电邮: zabbix@itwish.cn
勾选“已启用”
点击更新
http://s1.运维网.com/images/20181002/1538451882897656.png
[*] 用户配置(收件人邮箱配置):登陆web管理界面,进入“管理”——“用户”——“Admin”——“报警媒介”选项
类型:Email
收件人:***@qq.com
勾选“如果存在严重性则使用”相关选项
勾选“已启用”
点击更新
http://s1.运维网.com/images/20181002/1538453190290810.png
http://s1.运维网.com/images/20181002/1538453337478460.png
[*]动作配置:登陆web管理界面,进入“配置”——“动作”——“Report problems to Zabbix administrators”选项
名称:Report problems to Zabbix administrators
添加触发条件:“触发器示警度 = **”
勾选”已启用“
点击更新
http://s1.运维网.com/images/20181002/1538453491676532.png
[*]"操作"配置:登陆web管理界面,进入“配置”——“动作”——“Report problems to Zabbix administrators”——“操作”选项
默认操作时间: 1h
默认标题: 主机 {HOSTNAME} 在 {EVENT.DATE} {EVENT.TIME} 发生故障 {TRIGGER.NAME} {ITEM.VALUE}
告警主机:{HOSTNAME}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警项目:{TRIGGER.KEY}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE}
事件ID:{EVENT.ID}
勾选“维护期间暂停操作”
http://s1.运维网.com/images/20181009/1539068539743977.png
点击 “新的”
"操作细节"配置:
步骤:1 -1
操作类型:发送消息
发送到用户:添加指定用户
仅送到:Email
条件:“条件已确认 = 非确认”
点击 "添加"
点击“更新”
http://s1.运维网.com/images/20181009/1539068376117598.png
http://s1.运维网.com/images/20181009/1539068278493665.png
[*]恢复配置:登陆web管理界面,进入“配置”——“动作”——“Report problems to Zabbix administrators”——“恢复操作”选项
默认操作时间: 1h
默认标题: 主机 {HOSTNAME} 于 {EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME} 恢复故障 ,当前状态是 {ITEM.NAME} {ITEM.VALUE}
恢复主机:{HOSTNAME}
恢复时间:{EVENT.DATE} {EVENT.TIME}
恢复故障:{ITEM.NAME}:{ITEM.VALUE}
告警等级:{TRIGGER.SEVERITY}
恢复信息: {TRIGGER.NAME}
恢复项目:{TRIGGER.KEY}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE}
事件ID:{EVENT.ID}
http://s1.运维网.com/images/20181009/1539068764154979.png
点击 “新的”
"操作细节"配置
操作类型:发送消息
发送到用户:添加指定用户
仅送到:Email
点击 "添加"
点击“更新”
http://s1.运维网.com/images/20181009/1539068960474135.png
http://s1.运维网.com/images/20181009/1539068680718329.png
四、测试zabbix报警
关闭zabbix server 中zabbix_agentd 服务测试,关闭网络设备端口测试
在zabbix 3.4 服务器端配置本地账号进行邮件报警时,邮件发送失败。提示“cannot connect to SMTP server "**": cannot connect to [[**]:25]: Connection refused”。如下图
http://s1.运维网.com/images/20181004/1538661258519228.png
故障原因: zabbix服务器未监听主机 IP 25端口
解决方法:配置postfix 脚本配置文件,对服务器端主机ip地址进行监听
# vi /etc/postfix/ # 调整postfix 脚本配置文件
inet_interfaces = localhost,zabbix.itwish.cn,172.16.10.5 # 修改该项,把localhost 修改为localhost,zabbix.itwish.cn,172.16.10.5
# service postfix restart
Shutting down postfix:
Starting postfix:
# ss -tunl # 服务器监听本机ip 25端口
NetidState Recv-Q Send-Q Local Address:Port Peer Address:Port
tcp LISTEN 0 100 172.16.10.5:25 *:*
tcp LISTEN 0 100 127.0.0.1:25 *:*故障解决
http://s1.运维网.com/images/20181004/1538661845806905.png
邮箱验证
http://s1.运维网.com/images/20181004/1538662779337041.png
Zabbix Server使用互联网邮箱账号发送邮件报警
一、安装邮件发送工具mailx
# service postfix stop # 关闭postfix 服务
Shutting down postfix:
# chkconfig postfix off
# yum install mailx # 安装邮件发送工具
# echo "Hello word" | mailx -s "hello" 345876547@qq.com # 测试发送邮件
# whereis mailx # 查看mailx路径
mailx: /bin/mailx /usr/share/man/man1/mailx.1.gz /usr/share/man/man1p/mailx.1p.gz
# mailx -V # 查看mailx版本
12.4 7/29/08 二、配置Zabbix服务端外部邮箱
[*] 配置mailx配置文件mail.rc
# vi /etc/mail.rc #编辑,添加以下信息
set from=xxx@qq.com smtp=smtp.qq.com
set smtp-auth-user=xxx@qq.com smtp-auth-password=123456 # 分别为邮箱账号及邮箱密码
set smtp-auth=login
:wq! #保存退出
# echo "zabbix test mail" |mail -s "zabbix" 345876547@qq.com
#测试发送邮件,标题zabbix,邮件内容:zabbix test mail,发送到的邮箱:345876547@qq.com
[*] 邮箱测试 ,
http://s1.运维网.com/images/20181009/1539054032700474.png
三、配置zabbix邮件报警
[*] 报警介质类型配置:登陆web管理界面,进入“管理”——“报警媒介类型”——“Email”选项
名称 Email
SMTP服务器smtp.qq.com
SMTP服务器端口 25
SMTP HELO qq.com
SMTP电邮 345876547@qq.com
勾选“已启用”
点击更新
http://s1.运维网.com/images/20181009/1539056017254456.png
[*] 用户配置:进入“管理”——“用户”——“Admin”——“报警媒介”选项
类型Email
收件人***@qq.com
勾选“如果存在严重性则使用”相关选项
勾选“已启用”
点击更新
http://s1.运维网.com/images/20181002/1538453190290810.png
http://s1.运维网.com/images/20181002/1538453337478460.png
[*] 动作配置:登陆web管理界面,进入“配置”——“动作”——“Report problems to Zabbix administrators”选项
名称:Report problems to Zabbix administrators
添加触发条件:“触发器示警度 = **”
勾选”已启用“
点击更新
http://s1.运维网.com/images/20181002/1538453491676532.png
[*] "操作"配置:登陆web管理界面,进入“配置”——“动作”——“Report problems to Zabbix administrators”——“操作”选项
默认操作时间: 1h
默认标题: 主机 {HOSTNAME} 在 {EVENT.DATE} {EVENT.TIME} 发生故障 {TRIGGER.NAME} {ITEM.VALUE}
告警主机:{HOSTNAME}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息: {TRIGGER.NAME}
告警项目:{TRIGGER.KEY}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE}
事件ID:{EVENT.ID}
勾选“维护期间暂停操作”
http://s1.运维网.com/images/20181009/1539068539743977.png
点击 “新的”
"操作细节"
步骤:1 -1
操作类型:发送消息
发送到用户:添加指定用户
仅送到:Email
条件:“条件已确认 = 非确认”
点击 "添加"
点击“更新”
http://s1.运维网.com/images/20181009/1539068376117598.png
http://s1.运维网.com/images/20181009/1539068278493665.png
[*] 恢复配置:登陆web管理界面,进入“配置”——“动作”——“Report problems to Zabbix administrators”——“恢复操作”选项
默认操作时间: 1h
默认标题: 主机 {HOSTNAME} 于 {EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME} 恢复故障 ,当前状态是 {ITEM.NAME} {ITEM.VALUE}
恢复主机:{HOSTNAME}
恢复时间:{EVENT.DATE} {EVENT.TIME}
恢复故障:{ITEM.NAME}:{ITEM.VALUE}
告警等级:{TRIGGER.SEVERITY}
恢复信息: {TRIGGER.NAME}
恢复项目:{TRIGGER.KEY}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE}
事件ID:{EVENT.ID}
http://s1.运维网.com/images/20181009/1539068764154979.png
点击 “新的”
"操作细节"
操作类型:发送消息
发送到用户:添加指定用户
仅送到:Email
点击 "添加"
点击“更新”
http://s1.运维网.com/images/20181009/1539068960474135.png
http://s1.运维网.com/images/20181009/1539068680718329.png
四、测试zabbix 报警
模拟关闭监控的网络设备端口 ,观察zabbix报警状态
zabbix服务器端配置外网邮箱账号进行发送邮件时,邮件发送失败;提示: “Support for SMTP authentication was not compiled in ”
http://s1.运维网.com/images/20181009/1539058890709760.png
故障原因:要求curl版本最低7.20.0,系统curl版本号过低 。
解决办法:升级libcurl ,并重新编译zabbix
# curl -V # 查看curl版本号
curl 7.19.7 (x86_64-redhat-linux-gnu) libcurl/7.19.7 NSS/3.27.1 zlib/1.2.3 libidn/1.18 libssh2/1.4.2
# vi /etc/yum.repos.d/CentOS-Base.repo # 添加如下内容curl源
name=CentOS -$releasever - City-fan
baseurl=http://mirror.city-fan.org/ftp/contrib/yum-repo/rhel6Server/x86_64/
gpgcheck=0
enabled=1
# yum upgrade libcurl # 升级libcurl
# cd zabbix-3.4.14 # 进入zabbix解压包 ,重新编译安装
# ./configure \--prefix=/usr/local/zabbix \
--enable-server \
--enable-agent \
--enable-ipv6\
--with-mysql \
--with-libxml2 \
--with-net-snmp \
--with-libevent \
--with-openssl \
--with-libcurl \
--with-libpcre \
--with-iconv \
--with-ssh2 \
--with-ldap \
--with-openipmi
# make && make install
# service zabbix_server restart # 重启zabbix_server 服务
Shutting down zabbix_server:
Starting zabbix_server: 故障解决:
http://s1.运维网.com/images/20181009/1539060521205765.png
http://s1.运维网.com/images/20181009/1539060680488183.png
至此,通过配置两种方式,实现了邮件报警功能。分别是通过本地服务器发送邮件报警配置 及互联网邮箱账号发送邮件报警配置。
转载请注明出处:http://blog.运维网.com/itwish
页:
[1]