一、邮箱配置:开启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 from=592296813@qq.com ###用来发送邮件的邮箱账号,这里例子是qq邮箱 set smtp=smtps://smtp.qq.com:465 ###邮件服务器 set smtp-auth-user=592296813@qq.com ###发送邮件的账号 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 "这里是邮件主题" XXXXXXX@163.com
************************************************************************************************************************************************************************
【可跳过第三步】
三、编写邮件发送脚本:
(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