Zabbix邮件报警
咱们经过zabbix设置了监控项,触发器,最终就是要监控某一项达到报警的做用,下面是经过发送邮件报警的方式。web
web页面设置报警媒介
给Admin用户添加报警媒介
服务器报警配置
两个脚本:
第一个是zabbix调用的发送邮件的脚本. 他会调用第二个脚本去发送邮件.(Media types的script name:)vim
[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)bash
#下载并解压 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端的配置文件须要配置好执行脚本的路径(跟咱们存放脚本文件的目录须要一致)app
vim /etc/zabbix/zabbix_server.conf ... AlertScriptsPath=/usr/lib/zabbix/alertscripts
测试发送邮件可能会出现perl版本不兼容的状况,须要在sendemail.sh发送邮件的时候添加个参数测试
错误:spa
******************************************************************* 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.
解决:.net
$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
也可能会有受权错误:3d
Mar 20 16:37:19 rsjxqyf03 sendEmail[24611]: ERROR => ERROR => SMTP-AUTH: Authentication to smtp.163.com:25 failed.
检查邮箱是否开启smtp功能(默认是关闭的),用户名密码是否正确,若是都正确,可尝试将脚本一的邮箱密码改成受权码,如何得到受权码请自行百度。code
触发报警的动做
以上两步完成之后,咱们须要设置触发报警的动做
添加好了动做,能够将大文件拷贝进机器的根目录,触发触发器,便可发送邮件了。