Zabbix 通过smtp 邮件报警

Zabbix邮件报警

我们通过zabbix设置了监控项,触发器,最终就是要监控某一项达到报警的作用,下面是通过发送邮件报警的方式。

web页面设置报警媒介

 

给Admin用户添加报警媒介

 

服务器报警配置

两个脚本:
第一个是zabbix调用的发送邮件的脚本. 他会调用第二个脚本去发送邮件.(Media types的script name:)

[root@zabbix01 ~]# cat /usr/lib/zabbix/alertscripts/sendemail.sh 
#!/bin/bash
SMTP_server='smtp.163.com'    # SMTP服务器
username='xxxx@163.com'     # 用户名
password='xxxxxxxx'             # 密码
from_email_address='xxxx@163.com' # 发件人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/bin/sendEmail'
$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
echo "`date +"%F %T"` send to $to_email_address" >> /tmp/send.log


第二个是perl 写的sendemail专门用来通过smtp发送邮件的(对应第一个脚本中发送邮件的sendEmail)

#下载并解压
wget http://caspian.dotconf.net/menu/Software/SendEmail/sendEmail-v1.56.tar.gz
tar xvf sendEmail-v1.56.tar.gz
#把sendEmail复制到指定目录 并修改权限
cd sendEmail-v1.56
cp sendEmail /usr/bin/
chmod +x /usr/bin/sendEmail

上述两步完成后,可以先测试能否成功发送邮件

/usr/lib/zabbix/alertscripts/sendemail.sh 279790279@qq.com zabbixtest "blaze test email"

另外需要注意的是,server端的配置文件需要配置好执行脚本的路径(跟我们存放脚本文件的目录需要一致)

vim /etc/zabbix/zabbix_server.conf

...
AlertScriptsPath=/usr/lib/zabbix/alertscripts

测试发送邮件可能会出现perl版本不兼容的情况,需要在sendemail.sh发送邮件的时候添加个参数

错误:

*******************************************************************
 Using the default of SSL_verify_mode of SSL_VERIFY_NONE for client
 is deprecated! Please set SSL_verify_mode to SSL_VERIFY_PEER
 together with SSL_ca_file|SSL_ca_path for verification.
 If you really don't want to verify the certificate and keep the
 connection open to Man-In-The-Middle attacks please set
 SSL_verify_mode explicitly to SSL_VERIFY_NONE in your application.
*******************************************************************
  at /usr/bin/sendEmail line 1906.
invalid SSL_version specified at /usr/share/perl5/vendor_perl/IO/Socket/SSL.pm line 415.

解决:

$sendEmail -s "$SMTP_server" -xu "$username" -xp "$password" -f "$from_email_address" -t "$to_email_address" -u "$message_subject" -m "$message_body" -o tls=no message-content-type=text -o message-charset=gb2312
echo "`date +"%F %T"` send to $to_email_address" >> /tmp/send.log

 也可能会有授权错误:

Mar 20 16:37:19 rsjxqyf03 sendEmail[24611]: ERROR => ERROR => SMTP-AUTH: Authentication to smtp.163.com:25 failed.

检查邮箱是否开启smtp功能(默认是关闭的),用户名密码是否正确,如果都正确,可尝试将脚本一的邮箱密码改为授权码,如何获得授权码请自行百度。

 

触发报警的动作

以上两步完成以后,我们需要设置触发报警的动作

添加好了动作,可以将大文件拷贝进机器的根目录,触发触发器,即可发送邮件了。

 

posted @ 2019-03-19 14:16  青衫仗剑  阅读(1056)  评论(0编辑  收藏  举报