一、场景描述与流程介绍
在现代的企业环境中,实时监控和告警是确保系统和应用程序稳定运行的关键部分。为了及时获得关键事件和故障的通知,许多公司都在使用监控工具,如Zabbix,来监测其 IT 基础设施的状态。然而,仅仅监测并不足够,还需要确保监测到的问题能够迅速通知到相关人员,以便能够采取必要的行动。在这种情况下,企业微信机器人成为一个强大的工具,用于将实时告警通知传递给团队成员。
工作流程:
- 集成设置: 运维团队首先在企业微信中创建了一个机器人,并获取了一个唯一的Webhook URL。
- Zabbix配置: 在Zabbix中,设置告警动作,将告警通知发送到企业微信机器人的Webhook URL。这样,每当发生告警时,Zabbix会自动将告警信息发送给企业微信机器人。
- 实时通知: 当Zabbix监测到服务器或应用程序出现问题时,它会立即触发告警动作,并将告警信息发送给企业微信机器人。机器人会将告警消息以卡片的形式显示在团队成员的企业微信群中。
- 快速响应: 团队成员在企业微信中即时看到告警消息,可以立即采取行动。这消除了延迟,并帮助他们更快地响应和解决问题。
通过将Zabbix与企业微信机器人集成,可以更加高效地处理告警,减少了故障的响应时间,并确保业务的稳定性。这种实时告警通知的方案不仅提升了团队的效率,还增强了对问题的可见性和及时响应能力。
二、配置脚本执行目录
- 进入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)
三、文章来源(Source):浅时光博客 赋予脚本执行权限
[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.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
请问webhook地址在哪查看?
创建了机器人就自动生成了,点击机器人配置里看
谢谢分享