且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

Zabbix之微信企业号平台报警

更新时间:2022-09-22 12:12:31

                查看微信订阅号监控请点击


一、注册微信企业号

    因为订阅号的发送数量有限,很多时候超额发送之后会无法发送,现在我们申请企业号,因为企业号可以无限制的发送报警信息。

   打开注册地址https://qy.weixin.qq.com/

1、填写账号密码信息

Zabbix之微信企业号平台报警

2、邮箱激活

Zabbix之微信企业号平台报警


Zabbix之微信企业号平台报警

3、选择企业号

Zabbix之微信企业号平台报警

4、填写相关信息,注册成功

Zabbix之微信企业号平台报警


二、配置企业号

1、通讯录添加企业成员
    我们要提前把成员信息添加进组织部门,必填项+手机号或者微信号,这样别人扫描二维码的时候才能成功关注企业号。

   注意:这里有两个我们要用到信息,一个组织部门的ID,一个部门成员的账号(账号是自己手动指定的,不同于微信号,***是字母加数字)

Zabbix之微信企业号平台报警

    查看部门id,修改部门即可看到。

Zabbix之微信企业号平台报警

   在部门添加新成员。

Zabbix之微信企业号平台报警

    人员为扫描之前是?,扫描添加之后就正常了。

Zabbix之微信企业号平台报警


2、应用中心创建应用

    我们要在这里创建应用,因为要通过应用发送消息给部门成员,可以创建多个,不同的业务通过不同的应用发送出去,我这里创建的是运维部,这里要记住一个值,应用ID,后面的发送脚本会用到。

Zabbix之微信企业号平台报警


Zabbix之微信企业号平台报警


Zabbix之微信企业号平台报警

3、给部门设置管理组
    设置--->功能设置---->权限管理---->新建管理组,按照相应的信息设定好应用权限以及通讯录权限,里面的CorpID和Secret是我们后面脚本需要的。

Zabbix之微信企业号平台报警

三、调用微信接口

    调用微信接口需要一个调用接口的凭证:access_token,通过CropID 、Secret才能获取到access_token,但是获取到的token有效期为两分钟。

    微信企业号接口调试工具传送门:http://qydev.weixin.qq.com/debug。

    微信接口消息类型及格式。

http://qydev.weixin.qq.com/wiki/index.php?title=%E6%B6%88%E6%81%AF%E7%B1%BB%E5%9E%8B%E5%8F%8A%E6%95%B0%E6%8D%AE%E6%A0%BC%E5%BC%8F

Zabbix之微信企业号平台报警Zabbix之微信企业号平台报警

1、编辑微信Python脚本

1
# cat /usr/local/zabbix/alertscripts/yunwei.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#!/usr/bin/python
#coding:utf-8
 
import urllib2
import json
import sys
def getMsg(zabbix_msg):
    reload(sys)
    sys.setdefaultencoding('utf8')
    msg = ' '.join(zabbix_msg)
    msg = msg.split('#')
    mes="\n".join(msg)
    return "\n".join(msg)
 
 
if __name__ == '__main__':
    #微信公众号上应用的CropID和Secret
    CropID='wx8d46d36104988993'
    Secret='QCjzy2lH2ZB7MUG6uowChyChPssfsf6EB0X0QjofRRt0JePGezTVR4saIw3Ezznh'
  
    #获取access_token
    GURL="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=%s&corpsecret=%s" % (CropID,Secret)
    result=urllib2.urlopen(urllib2.Request(GURL)).read()
    dict_result = json.loads(result)
    dict_result.keys()
    Gtoken = dict_result['access_token']
     
    #生成通过post请求发送消息的url
    PURL="https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % (Gtoken)
     
    AppID=4                        #企业号中的应用id
#   UserID=2                       #部门成员id,zabbix中定义的微信接收者
    PartyID=2                      #部门id,定义了范围,组内成员都可接收到消息
 
    #生成post请求信息
    post_data = {}
    news = {}
    articles = {}
    articles['description'= getMsg(sys.argv[3:])
    articles['title'= getMsg(sys.argv[2:3])
    news['articles'= [articles]
 
    #post_data['touser'] = UserID
    post_data['toparty'= PartyID
    post_data['msgtype'= 'news'
    post_data['agentid'= AppID
    post_data['news'= news
    #post_data['safe'] = '0'
    #由于字典格式不能被识别,需要转换成json然后在作post请求
    #注:如果要发送的消息内容有中文的话,第三个参数一点要设为False
    json_post_data = json.dumps(post_data,False,False)
    #通过urllib2.urlopen()方法发送post请求
    request_post = urllib2.urlopen(PURL, json_post_data)
    #read()方法查看请求的返回结果
    print request_post.read()

2、配置脚本权限

1
2
chown zabbix.zabbix /usr/local/zabbix/alertscripts/yunwei.py
chmod +x /usr/local/zabbix/alertscripts/yunwei.py

3、测试脚本

    由脚本可以看出,我们不但可以使用zabbix报警,也可以使用任何shell报警。

1
2
[root@monitor alertscripts]# python /usr/local/zabbix/alertscripts/yunwei.py test
{"errcode":0,"errmsg":"ok"}

Zabbix之微信企业号平台报警

    可以看到可以正常的调用接口,我们接着配置zabbix。


四、配置Zabbix

1、创建媒介

Zabbix之微信企业号平台报警

2、给用户增加媒介

Zabbix之微信企业号平台报警

Zabbix之微信企业号平台报警

3、创建触发器

Zabbix之微信企业号平台报警

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
======================================================
服务器:{HOST.NAME}发生: {TRIGGER.NAME}故障!
 
{
告警主机:{HOST.NAME}
告警地址:{HOST.IP}
告警时间:{EVENT.DATE} {EVENT.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息:{TRIGGER.NAME}
监控项目:{ITEM.NAME}
当前状态:{TRIGGER.STATUS}
持续时间:{EVENT.AGE}
事件ID:{EVENT.ID}
监控取值:{ITEM.LASTVALUE}
}
=====================================================
服务器:{HOST.NAME}: {TRIGGER.NAME}已恢复!
 
{
告警主机:{HOST.NAME}
告警地址:{HOST.IP}
告警时间:{EVENT.DATE} {EVENT.TIME}
恢复时间:{EVENT.RECOVERY.DATE} {EVENT.RECOVERY.TIME}
告警等级:{TRIGGER.SEVERITY}
告警信息:{TRIGGER.NAME}
监控项目:{ITEM.NAME}
当前状态:{TRIGGER.STATUS}
持续时间:{EVENT.AGE}
事件ID:{EVENT.ID}
监控取值:{ITEM.LASTVALUE}
}
====================================================

Zabbix之微信企业号平台报警

    Send only to选择我们设定的媒介。

Zabbix之微信企业号平台报警

3、测试

Zabbix之微信企业号平台报警



附录:Shell脚本

1、编辑微信Shell脚本

    上面是Python的脚本,下面我贴一下Shell的脚本,其他的配置信息都是一样的,使用其中一个就可以了。

1
# cat /usr/local/zabbix/alertscripts/yunwei.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#!/bin/bash
#########################################################################
# File Name: yunwei_bash.sh
# Author: wzlinux
# Email: wangzan18@126.com
# Created Time: 2017.4.17
#########################################################################
# Functions: send messages to wechat app
# set variables
CropID='wx8d46d36104988993'
Secret='QCjzy2lH2ZB7MUG6uowChyChPsOQwsdf0X0QjofRRt0JePGezTVR4saIw3Ezznh'
GURL="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$CropID&corpsecret=$Secret"
#get acccess_token
Gtoken=$(/usr/bin/curl -s -G $GURL | awk -F\" '{print $4}')
PURL="https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=$Gtoken"
#
function body() {
local int AppID=4                        #企业号中的应用id
#local UserID="eric"                     #部门成员id,zabbix中定义的微信接收者
local PartyID=2                          #部门id,定义了范围,组内成员都可接收到消息
local Msg=$(echo "$@" cut -d" " -f3-)  #过滤出zabbix传递的第三个参数
printf '{\n'
printf '\t"touser": "'"$UserID"\"",\n"
printf '\t"toparty": "'"$PartyID"\"",\n"
printf '\t"msgtype": "text",\n'
printf '\t"agentid": "'" $AppID "\"",\n"
printf '\t"text": {\n'
printf '\t\t"content": "'"$Msg"\""\n"
printf '\t},\n'
printf '\t"safe":"0"\n'
printf '}\n'
}
/usr/bin/curl --data-ascii "$(body $1 $2 $3)" $PURL
1
2
chown zabbix.zabbix /usr/local/zabbix/alertscripts/yunwei.sh
chmod +x /usr/local/zabbix/alertscripts/yunwei.sh

5、测试

# bash yunwei.sh test Hello.World!

{"errcode":0,"errmsg":"ok"}

这里我不再进行截图了,我这边测试是通过的




     本文转自 wzlinux 51CTO博客,原文链接:http://blog.51cto.com/wzlinux/1916772,如需转载请自行联系原作者