Zabbix / 监控平台

实时告警通知:Zabbix集成企业微信机器人

浅时光博客 · 2月23日 · 2020年 15.8w 次已读

一、场景描述与流程介绍

在现代的企业环境中,实时监控和告警是确保系统和应用程序稳定运行的关键部分。为了及时获得关键事件和故障的通知,许多公司都在使用监控工具,如Zabbix,来监测其 IT 基础设施的状态。然而,仅仅监测并不足够,还需要确保监测到的问题能够迅速通知到相关人员,以便能够采取必要的行动。在这种情况下,企业微信机器人成为一个强大的工具,用于将实时告警通知传递给团队成员。

工作流程:

  1. 集成设置: 运维团队首先在企业微信中创建了一个机器人,并获取了一个唯一的Webhook URL。
  2. Zabbix配置: 在Zabbix中,设置告警动作,将告警通知发送到企业微信机器人的Webhook URL。这样,每当发生告警时,Zabbix会自动将告警信息发送给企业微信机器人。
  3. 实时通知: 当Zabbix监测到服务器或应用程序出现问题时,它会立即触发告警动作,并将告警信息发送给企业微信机器人。机器人会将告警消息以卡片的形式显示在团队成员的企业微信群中。
  4. 快速响应: 团队成员在企业微信中即时看到告警消息,可以立即采取行动。这消除了延迟,并帮助他们更快地响应和解决问题。

通过将Zabbix与企业微信机器人集成,可以更加高效地处理告警,减少了故障的响应时间,并确保业务的稳定性。这种实时文章来源(Source):https://www.dqzboy.com告警通知的方案不仅提升了团队的效率,还增强了对问题的可见性和及时响应能力。

二、配置脚本执行目录

  • 进入zabbix自定义脚本目录,在zabbix server安装目录定义的
  • conf配置文件在zabbix安装目录下的zabbix_server.conf里面定义的脚本执行目录
  • AlertScriptsPath=/usr/lib/zabbix/alertscripts
[root@zabbix-server ~]# grep -Ev '^$|#' /etc/zabbix/zabbix_server.conf | grep ^A
AlertScriptsPath=/usr/lib/zabbix/alertscripts

三、创建告警推送脚本

说明:以下脚本是基于Python2环境执行的

[root@zabbix-server ~]# cd /usr/lib/zabbix/alertscripts
[root@zabbix-server alertscripts]# vim wechat.py
#!/usr/bin/python
# -*- coding: utf-8 -*-
import requests
import json
import sys
import os

headers = {'Content-Type': 'application/json;charset=utf-8'}
api_url = " https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=xxxxxxxx"   #这个是webhook地址,修改为你的即可。

def msg(text):
    json_text= {
     "msgtype": "text",
        "text": {
            "content": text
        },
    }
    print requests.post(api_url,json.dumps(json_text),headers=headers).content

if __name__ == '__main__':
    text = sys.argv[1]
    msg(text)

三、赋予脚本执行权限

[root@zabbix-server alertscripts]# chmod +x wechat.py
  • 测试脚本
[root@zabbix-server alertscripts]# python wechat.py 您好,监控测试

四、企业微信查看

五、Zabbix页面定义报警

5.1:创建报警媒介

  • 管理–>报警媒介类型–>创建媒介类型
  • 新建一个企业微信的报警,脚本名称就是我们脚本名wechat.py

5.2:创建动作

5.2.1: 动作【操作】

  • 操作内容信息如下:
  • 默认标题:
    • 故障{TRIGGER.STATUS},服务器:{HOST.NAME}发生: {TRIGGER.NAME}故障!
  • 消息内容:
    • 告警主机:{HOST.NAME}
    • 告警地址:{HOST.IP}
    • 监控项目:{ITEM.NAME}
    • 监控取值:{ITEM.LASTVALUE}
    • 告警等级:{TRIGGER.SEVERITY}
    • 当前状态:{TRIGGER.STATUS}
    • 告警信息:{TRIGGER.NAME}
    • 告警时间:{EVENT.DATE} {EVENT.TIME}
    • 事件ID:{EVENT.ID}

5.文章来源(Source):浅时光博客2.2:动作【恢复操作】

  • 恢复操作内容信息如下:
  • 默认标题:
    • 恢复{TRIGGER.STATUS}, 服务器:{HOSTNAME1}: {TRIGGER.NAME}已恢复!
  • 消息内容:
    • 告警主机:{HOST.NAME}
    • 告警地址:{HOST.IP}
    • 监控项目:{ITEM.NAME}
    • 监控取值:{ITEM.LASTVALUE}
    • 告警等级:{TRIGGER.SEVERITY}
    • 当前状态:{TRIGGER.STATUS}
    • 告警信息:{TRIGGER.NAME}
    • 告警时间:{EVENT.DATE} {EVENT.TIME}
    • 恢复时间:{EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME}
    • 持续时间:{EVENT.AGE}
    • 事件ID:{EVENT.ID}
  • 最后点击添加

5.3:测试发送告警

可以将被监控端的agent停止(首先保证该被监控主机有对应的监控项和触发器)

[root@localhost ~]# systemctl stop zabbix-agent

本文作者:浅时光博客
原文链接:https://www.dqzboy.com/1112.html
版权声明:知识共享署名-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)协议进行许可,转载时请以>超链接形式标明文章原始出处和作者信息
免责声明:本站内容仅供个人学习与研究,严禁用于商业或非法目的。请在下载后24小时内删除相应内容。继续浏览或下载即表明您接受上述条件,任何后果由用户自行承担。

3 条回应

必须 注册 为本站用户, 登录 后才可以发表评论!

  1. %@#$%&*.......上海2021-5-28 · 18:12

    请问webhook地址在哪查看?

    • 浅时光博客2021-5-28 · 18:59

      创建了机器人就自动生成了,点击机器人配置里看

  2. 凡人多烦事未知2020-8-2 · 23:34

    谢谢分享