查看微信订阅号监控请点击
一、注册微信企业号
因为订阅号的发送数量有限,很多时候超额发送之后会无法发送,现在我们申请企业号,因为企业号可以无限制的发送报警信息。
打开注册地址https://qy.weixin.qq.com/。
1、填写账号密码信息

2、邮箱激活


3、选择企业号

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

二、配置企业号
1、通讯录添加企业成员
我们要提前把成员信息添加进组织部门,必填项+手机号或者微信号,这样别人扫描二维码的时候才能成功关注企业号。
注意:这里有两个我们要用到信息,一个组织部门的ID,一个部门成员的账号(账号是自己手动指定的,不同于微信号,最好是字母加数字)

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

在部门添加新成员。

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

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



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

三、调用微信接口
调用微信接口需要一个调用接口的凭证: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


1、编辑微信Python脚本
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
|
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 = 'wx8d46d36104988993'
Secret = 'QCjzy2lH2ZB7MUG6uowChyChPssfsf6EB0X0QjofRRt0JePGezTVR4saIw3Ezznh'
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' ]
PURL = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % (Gtoken)
AppID = 4
PartyID = 2
post_data = {}
news = {}
articles = {}
articles[ 'description' ] = getMsg(sys.argv[ 3 :])
articles[ 'title' ] = getMsg(sys.argv[ 2 : 3 ])
news[ 'articles' ] = [articles]
post_data[ 'toparty' ] = PartyID
post_data[ 'msgtype' ] = 'news'
post_data[ 'agentid' ] = AppID
post_data[ 'news' ] = news
json_post_data = json.dumps(post_data, False , False )
request_post = urllib2.urlopen(PURL, json_post_data)
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]
{ "errcode" :0, "errmsg" : "ok" }
|

可以看到可以正常的调用接口,我们接着配置zabbix。
四、配置Zabbix
1、创建媒介

2、给用户增加媒介


3、创建触发器

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}
}
====================================================
|

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

3、测试

附录:Shell脚本
1、编辑微信Shell脚本
上面是Python的脚本,下面我贴一下Shell的脚本,其他的配置信息都是一样的,使用其中一个就可以了。
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
CropID= 'wx8d46d36104988993'
Secret= 'QCjzy2lH2ZB7MUG6uowChyChPsOQwsdf0X0QjofRRt0JePGezTVR4saIw3Ezznh'
GURL= "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$CropID&corpsecret=$Secret"
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
local PartyID=2
local Msg=$( echo "$@" | cut -d " " -f3-)
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,如需转载请自行联系原作者