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功能(默认是关闭的),用户名密码是否正确,如果都正确,可尝试将脚本一的邮箱密码改为授权码,如何获得授权码请自行百度。
触发报警的动作
以上两步完成以后,我们需要设置触发报警的动作
添加好了动作,可以将大文件拷贝进机器的根目录,触发触发器,即可发送邮件了。