zabbix4.2配置邮件报警:以QQ邮箱为例

一、邮箱配置:开启smtp服务和授权

  开启smtp选项后,系统会生成一个授权,你需要记住这个授权码,后面需要写入配置文件。

二、配置管理mailx:

  (1)安装mailx:[root@zabbix-server-center ~]# yum install -y mailx

    (2)请求数字证书(这里以qq邮箱为例):

[root@zabbix-server-center ~]# mkdir -p /home/zabbix/.certs
[root@zabbix-server-center ~]# echo -n | openssl s_client -connect smtp.qq.com:465 | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' > /home/zabbix/.certs/qq.crt
depth=2 C = US, O = DigiCert Inc, OU = www.digicert.com, CN = DigiCert Global Root CA
verify return:1
depth=1 C = US, O = DigiCert Inc, OU = www.digicert.com, CN = GeoTrust RSA CA 2018
verify return:1
depth=0 C = CN, ST = Guangdong, L = Shenzhen, O = Tencent Technology (Shenzhen) Company Limited, OU = R&D, CN = pop.qq.com
verify return:1
DONE

  

[root@zabbix-server-center zabbix]# certutil -A -n "GeoTrust SSL CA" -t "C,," -d /home/zabbix/.certs -i /home/zabbix/.certs/qq.crt
[root@zabbix-server-center zabbix]# certutil -A -n "GeoTrust Global CA" -t "C,," -d /home/zabbix/.certs -i /home/zabbix/.certs/qq.crt
[root@zabbix-server-center zabbix]# cd /home/zabbix/.certs/

  

[root@zabbix-server-center .certs]# certutil -A -n "GeoTrust SSL CA - G3" -t "Pu,Pu,Pu" -d ./ -i qq.crt
Notice: Trust flag u is set automatically if the private key is present.
[root@zabbix-server-center .certs]# certutil -L -d /home/zabbix/.certs

Certificate Nickname                                         Trust Attributes
                                                             SSL,S/MIME,JAR/XPI

GeoTrust SSL CA                                              P,P,P
[root@zabbix-server-center .certs]# chown -R zabbix.zabbix /home/zabbix/

  (3)修改/etc/mail.rc文件:[root@zabbix-server-center ~]# vim /etc/mail.rc

set [email protected]  ###用来发送邮件的邮箱账号,这里例子是qq邮箱
set smtp=smtps://smtp.qq.com:465   ###邮件服务器
set [email protected]   ###发送邮件的账号
set smtp-auth-password=XXXXXXXXX   ###这里是qq邮箱系统提供的“授权码”
set smtp-auth=login      ###默认login即可
set ssl-verify=ignore       ###ssl认证方式,这里选择忽略
set nss-config-dir=/home/zabbix/.certs   ###申请的证书所在目录

  (4)发送邮件进行测试:

[root@zabbix-server-center ~]# echo "这里是邮件正文" | mail -s "这里是邮件主题" [email protected] 

 ************************************************************************************************************************************************************************

【可跳过第三步】

三、编写邮件发送脚本:

  (1)创建shell脚本文件:

[root@zabbix-server-center zabbix]#vim /usr/lib/zabbix/alertscripts/mailx.sh

  (2)修改zabbix_server.conf配置文件中alertscripts路径(也就是存放邮件脚本的路径):

  (3)重启zabbix服务:

[root@zabbix-server-center /]# systemctl restart zabbix-server.service

  (4)设置邮件脚本文件:

#!/bin/bash
echo "$3" | mail -s "$2" "$1"

  (5)设置权限:

[root@zabbix-server-center alertscripts]#chmod +x /usr/lib/zabbix/alertscripts/mailx.sh
[root@zabbix-server-center alertscripts]#chown zabbix:zabbix /usr/lib/zabbix/alertscripts/mailx.sh

  (6)进入zabbix的web控制台,设置报警类型:

  (7)其余配置和直接设置邮件报警一致。

************************************************************************************************************************************************************************

四、进入zabbix的web控制台:

 

 

 

 操作配置:

默认标题:
故障:{TRIGGER.STATUS},服务器:{HOSTNAME1},发生:{TRIGGER.NAME}

消息内容:
告警主机:{HOST.NAME}
告警IP:{HOST.IP}
告警时间:{EVENT.DATE}-{EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息:{TRIGGER.NAME}:{ITEM.VALUE}
问题详情:{ITEM.NAME}:{ITEM.VALUE}
当前状态:{TRIGGER.STATUS}:{ITEM.VALUE}
事件ID:{EVENT.ID}

 

 

 

 五、测试邮件报警:

   出现以下信息,表明邮件发送是通的,可以正常发送报警邮件。

进入接受邮箱,发现已经成功接收到测试邮件:

 模拟测试关闭httpd服务,不久将会收到邮件报警,如下:

好文:https://blog.whsir.com/post-4385.html

           https://blog.csdn.net/qq_42988210/article/details/92050440

猜你喜欢

转载自www.cnblogs.com/python-wen/p/11405428.html