一、注册微信企业号
因为订阅号的发送数量有限,很多时候超额发送之后会无法发送,现在我们申请企业号,因为企业号可以无限制的发送报警信息。
打开注册地址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
|
# 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
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
|
# 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,如需转载请自行联系原作者