Zabbix对接企业微信Python3 Code

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
 
1、查看Zabbix Script存放位置

grep -i AlertScriptsPath /etc/zabbix/zabbix_server.conf
#AlertScriptsPath=/usr/lib/zabbix/alertscripts

2、编写Python Code

#!/usr/bin/python3
import urllib.request
import json
import sys
import simplejson


def gettoken(corpid, corpsecret):

    gettoken_url = 'https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=' + corpid + '&corpsecret=' + corpsecret
    print(gettoken_url)
    try:
        token_file = urllib.request.urlopen(gettoken_url)
    except Exception as e:
        print(e)
        sys.exit()
    token_data = token_file.read().decode('utf-8')
    token_json = json.loads(token_data)
    token_json.keys()
    token = token_json['access_token']
    return token


def senddata(access_token, subject, content):

    send_url = 'https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=' + access_token
    send_values = {
        "touser": "user",    # 企业号中的用户帐号,在zabbix用户Media中配置,如果配置不正常,将按部门发送。
        "toparty": gid,      # 企业号中的部门id,这个gid是zabbix传入的,变化的。
        "msgtype": "text",   # 消息类型。
        "agentid": "1000002",    # 企业号中的应用id。
        "text": {
            "content": subject + '\n' + content
          },
        "safe": "0"
        }

    send_data = simplejson.dumps(send_values, ensure_ascii=False).encode('utf-8')
    send_request = urllib.request.Request(send_url, send_data)
    response = json.loads(urllib.request.urlopen(send_request).read())
    print(str(response))


if __name__ == '__main__':
    gid = str(sys.argv[1])      # zabbix传过来的第一个参数,这里获取的是微信子部门的ID
    subject = str(sys.argv[2])  # zabbix传过来的第二个参数
    content = str(sys.argv[3])  # zabbix传过来的第三个参数
    corp_id = 'This is corpid'  # CorpID是企业号的标识
    corp_secret = 'This is corp secret'  # corpsecretSecret是管理组凭证密钥
    access_token = gettoken(corp_id, corp_secret)
    senddata(access_token, subject, content)

3、赋予脚本执行权限并重启Zabbix Service

chmod +x wechat.py
systemctl restart zabbix-server

4、测试脚本可用性

./wechat.py 2 server_exception ‘server xxx down!’           #这里的 “2” 是企业微信通讯录部门ID

剩下的就是在Zabbix web配置了!

### Zabbix配置企业微信告警的Python脚本方法 为了实现Zabbix企业微信之间的告警集成,可以通过编写一个Python脚本来完成这一功能。以下是详细的说明以及示例代码。 #### 1. 准备工作 在开始之前,需要确认以下几点: - 已经获取到企业微信机器人的Webhook地址[^4]。 - 确认Zabbix服务器上已经安装了`python3`及其依赖库(如`requests`),并确保可以正常运行Python脚本。 - 如果使用的是Docker部署的Zabbix Server,则可能无法找到默认的`/usr/lib/zabbix/alertscripts/`目录和配置文件`zabbix_server.conf`。这种情况下,建议通过Webhook方式替代传统脚本执行[^3]。 #### 2. 编写Python脚本 下面是一个用于向企业微信发送告警信息的Python脚本示例: ```python #!/usr/bin/env python3 import sys import requests import json def send_wechat_message(webhook_url, message, mentioned_list=None): headers = {'Content-Type': 'application/json'} data = { "msgtype": "text", "text": { "content": message, "mentioned_list": mentioned_list or [] } } response = requests.post(url=webhook_url, headers=headers, data=json.dumps(data)) return response.json() if __name__ == "__main__": webhook_url = sys.argv[1] subject = sys.argv[2] body = sys.argv[3] full_message = f"{subject}\n{body}" result = send_wechat_message(webhook_url, full_message) if result.get('errcode') != 0: print(f"Failed to send message: {result}") else: print("Message sent successfully.") ``` 此脚本的功能如下: - 接收三个参数:分别是企业微信机器人的Webhook URL、主题(Subject)、正文内容(Body)。 - 将接收到的信息组合成一条完整的告警消息,并通过POST请求将其发送给指定的企业微信群聊机器人。 #### 3. 设置权限并放置脚本 将上述脚本保存为`wechat_alarm.py`,然后赋予其可执行权限: ```bash chmod +x /path/to/wechat_alarm.py ``` 接着把该脚本复制到Zabbix预定义的报警脚本路径下,默认位置通常位于`/usr/lib/zabbix/alertscripts/`。 #### 4. 配置Zabbix媒介类型 登录到Zabbix Web界面,在“管理”->“媒体类型”中新增一种名为“Enterprise WeChat”的自定义媒体类型。设置命令行模板为: ```bash /path/to/wechat_alarm.py "{PARAMS[1]}" "{ALERT.SUBJECT}" "{ALERT.MESSAGE}" ``` 其中`{PARAMS[1]}`应替换为企业微信实际使用的Webhook链接。 #### 5. 测试验证 最后一步就是创建一个新的动作(Action),并将这个新设好的媒体类型关联起来进行测试。当触发条件满足时,应该能够看到相应的通知推送到目标企业微信群组里去了。 --- ### 注意事项 务必妥善保管好企业的Webhook地址,切勿随意泄露出去以免造成不必要的麻烦或者安全风险!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值