19.13/19.14 配置邮件告警

配置邮件告警

  • 使用163或者QQ邮箱发告警邮件
  • 首先登录你的163邮箱,设置开启POP3、IMAP、SMTP服务
  • 开启并记录授权码
  • 然后到监控中心设置邮件告警
  • “管理”,“报警媒介类型”,“创建媒体类型”
  • {ALERT.SENDTO} ,{ALERT.SUBJECT},{ALERT.MESSAGE}
  • 创建报警脚本mail.py
  • vim /usr/lib/zabbix/alertscripts/mail.py//内容参考
  • chmod 755 /usr/lib/zabbix/alertscripts/mail.py
  • 创建一个接受告警邮件的用户,“管理”,“用户”,“创建用户”,“报警媒介”,类型选择“baojing”,注意用户的权限,如果没有需要到用户组去设置权限
  • 设置动作,“配置”,“动作”,“创建动作”,名称写“sendmail”(自定义),“操作”页面,内容如下
HOST:{HOST.NAME} {HOST.IP}
TIME:{EVENT.DATE}  {EVENT.TIME} 
LEVEL:{TRIGGER.SEVERITY} 
NAME:{TRIGGER.NAME}
messages:{ITEM.NAME}:{ITEM.VALUE}
ID:{EVENT.ID}
  • “新的触发条件”,A维护状态 非在 维护,B触发器示警度>=未分类
  • “操作”,选择发送的用户为刚创建的用户,仅送到选择“baojing”
  • 切换到“恢复操作”,把信息改成如下
HOST:{HOST.NAME} {HOST.IP}
TIME:{EVENT.DATE}  {EVENT.TIME} 
LEVEL:{TRIGGER.SEVERITY} 
NAME:{TRIGGER.NAME}
messages:{ITEM.NAME}:{ITEM.VALUE}
ID:{EVENT.ID}
  • 点击“新的”,“操作”,选择发送的用户为刚创建的用户,仅送到选择“baojing”
  • 测试告警

配置邮件告警

  1. 首先需要一个邮箱,使用邮箱发邮件(163邮箱)
  2. 访问163邮箱,在第三方平台上调用163邮箱发邮件,需要设置开启POP3、IMAP、SMTP服务
  • 设置——POP3/IMAP/SMTP
    • 第一次开启POP3/IMAP/SMTP服务会有短信验证
    • 在验证完之后还需要设置客户端授权密码(需要牢记),接下来发邮件的密码就是授权密码
  1. 在写脚本之前 进入zabbix的web界面——> 管理——> 报警媒介类型——>创建媒体类型
  • 在报警媒介类型里面的自带的 Email 使用不方便,所以自己写python发邮件的脚本
  • 名称:指的是报警媒介类型的名称,自定义,这里叫做 baojing
  • 类型:脚本
  • 脚本名称:自定义,这里叫做 mail.py
  • 在py脚本参数下,三个参数都分布在py的脚本里
    • {ALERT.SENDTO} 表示收件人
    • {ALERT.SUBJECT} 表示邮件主题
    • {ALERT.MESSAGE} 表示邮件内容
  1. 这时会看到成功添加 baojing 报警媒介类型
  1. 要实现报警,首先py脚本能发出邮件
  2. 在服务端(A机器)创建报警脚本mail.py,查看报警脚本所在位置
A机器
[root@hf-01 ~]# vim /etc/zabbix/zabbix_server.conf

搜索 /alert
AlertScriptsPath=/usr/lib/zabbix/alertscripts
#报警脚本所在路径
  1. 创建报警脚本mail.py,在/usr/lib/zabbix/alertscripts/目录下是空的, 来创建,脚本内容参考
[root@hf-01 ~]# vim /usr/lib/zabbix/alertscripts/mail.py

#!/usr/bin/env python
#-*- coding: UTF-8 -*-
import os,sys
reload(sys)
sys.setdefaultencoding('utf8')
import getopt
import smtplib
from email.MIMEText import MIMEText
from email.MIMEMultipart import MIMEMultipart
from  subprocess import *
def sendqqmail(username,password,mailfrom,mailto,subject,content):
    gserver = 'smtp.163.com'
##定义发邮件类型
    gport = 25
    try:
        msg = MIMEText(unicode(content).encode('utf-8'))
        msg['from'] = mailfrom
        msg['to'] = mailto
        msg['Reply-To'] = mailfrom
        msg['Subject'] = subject
        smtp = smtplib.SMTP(gserver, gport)
        smtp.set_debuglevel(0)
        smtp.ehlo()
        smtp.login(username,password)
        smtp.sendmail(mailfrom, mailto, msg.as_string())
        smtp.close()
    except Exception,err:
        print "Send mail failed. Error: %s" % err
def main():
    to=sys.argv[1]
    subject=sys.argv[2]
    content=sys.argv[3]
##定义QQ邮箱的账号和密码,你需要修改成你自己的账号和密码(请不要把真实的用户名和密码放到网上公开,否则你会死的很惨)
    sendqqmail('163邮箱','密码','163邮箱',to,subject,content)

if __name__ == "__main__":
    main()
    
    
#####脚本使用说明######
#1. 首先定义好脚本中的邮箱账号和密码
#2. 脚本执行命令为:python mail.py 目标邮箱 "邮件主题" "邮件内容"

保存退出
  1. 更改mail.py脚本的权限(很重要!!!),否则就会无法告警
  • chmod 755 /usr/lib/zabbix/alertscripts/mail.py
[root@hf-01 ~]# chmod 755 /usr/lib/zabbix/alertscripts/mail.py
[root@hf-01 ~]# 
  1. 测试mail.py是否能发邮件,定义三个参数,若是给QQ的邮箱发邮件有可能会收不到
[root@hf-01 ~]# cd /usr/lib/zabbix/alertscripts/
[root@hf-01 alertscripts]# 
  • 这里好像mail.py 脚本有错误
[root@hf-01 alertscripts]# python mail.py han1118feng@163.com "ssss"
Traceback (most recent call last):
  File "mail.py", line 35, in <module>
    main()
  File "mail.py", line 31, in main
    content=sys.argv[3]
IndexError: list index out of range
[root@hf-01 alertscripts]# 
  • 创建一个接受告警邮件的用户,“管理”,“用户”,“创建用户”,“报警媒介”,类型选择“baojing”,注意用户的权限,如果没有需要到用户组去设置权限
  • 设置动作,“配置”,“动作”,“创建动作”,名称写“sendmail”(自定义),“操作”页面,内容如下
HOST:{HOST.NAME} {HOST.IP}
TIME:{EVENT.DATE}  {EVENT.TIME} 
LEVEL:{TRIGGER.SEVERITY} 
NAME:{TRIGGER.NAME}
messages:{ITEM.NAME}:{ITEM.VALUE}
ID:{EVENT.ID}
  • “新的触发条件”,A维护状态 非在 维护,B触发器示警度>=未分类
  • “操作”,选择发送的用户为刚创建的用户,仅送到选择“baojing”
  • 切换到“恢复操作”,把信息改成如下
HOST:{HOST.NAME} {HOST.IP}
TIME:{EVENT.DATE}  {EVENT.TIME} 
LEVEL:{TRIGGER.SEVERITY} 
NAME:{TRIGGER.NAME}
messages:{ITEM.NAME}:{ITEM.VALUE}
ID:{EVENT.ID}
  • 点击“新的”,“操作”,选择发送的用户为刚创建的用户,仅送到选择“baojing”
  • 测试告警

要实现报警,首先py脚本能发出邮件

.

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏大魏分享(微信公众号:david-share)

Openshift 3.11的14大新功能详解

聂健是大魏的红帽同事,本文已获得授权转载,欢迎读者阅读他的技术blog:https://www.cnblogs.com/ericnie/

9523
来自专栏FreeBuf

披着狼皮的羊:HP打印机远程代码执行漏洞(RCE)是这样被发现的

? 打印机作为组织机构内部不可缺少的资产设备,近年来,随着各种打印固件漏洞百出,其安全性也备受关注,打印机安全与电脑安全同等重要,不容忽视。我们注意到,惠普(...

2585
来自专栏黑泽君的专栏

网络通信的三要素

5124
来自专栏蓝天

C/C++编程可用的Linux自带工具

GNU Binary Utilities或binutils是一整套的编程语言工具程序,用来处理许多格式的目标文件。当前的版本原本由在Cygnus Soluti...

1302
来自专栏程序员与猫

JSON Patch

2791
来自专栏程序员与猫

JSON Patch

1326
来自专栏上善若水

014android初级篇之基于GraphView绘制统计图表

在android的开发过程中,需要使用图表,图表有第三方的插件实现了该功能。目前有很多类似的功能插件,比如achartengine, Graphview等等。G...

2296
来自专栏Seebug漏洞平台

披着狼皮的羊——寻找惠普多款打印机中的RCE漏洞

原文:https://foxglovesecurity.com/2017/11/20/a-sheep-in-wolfs-clothing-finding-rce...

973
来自专栏SDNLAB

SDN私享汇(十三):DCFabirc控制器实现高级OpenStack网络功能

DCFabirc的主要特性和基于DCFabric的OpenStack网络的高性能优势。DCFabric的最新版本“秦”在峰会上正式发布,新版本主要在多线程优化、...

2642
来自专栏针针小站

【Skill】斐讯K2T – 从Telnet到退货

首先先确认一下路由器的系统版本 确保系统在140版本以下 因为140以上的系统修复了这个漏洞 无法开启Telnet

2691

扫码关注云+社区