1、微信企业号注册与使用
企业号注册:https://qy.weixin.qq.com/
2、企业号使用教程
2.1、通讯录添加企业员工
登录新建的企业号,通过提前把企业成员信息添加到组织或者部门,需要填写手机号、微信号或邮箱,通过这样方式让别人扫码关注企业公众号,为了后面企业号推送消息给企业成员。
#新增账户,填写信息
3、应用中心创建应用
#可见范围还可以添加不同管理组,接受同一个应用推送的消息
4、给部门设置管理员
设置--->功能设置---->权限管理---->新建管理组
管理员需要事先关注企业号,并且设置好邮箱地址
#需要确定管理员有权限使用应用发送消息,需要管理员的CorpID和Sercrt。(重要)
#准备事项:
微信企业号
企业号已经被部门成员关注
企业号有一个可以发送消息的应用(test-msg),一个授权管理员(test-msg),可以使用应用给成员发送消息
#需要先添加管理员信息,然后使其关注企业号
#需要得到的信息
成员账号
组织部门ID
应用ID
CorpID和Secret
5、微信接口调用
调用微信接口需要一个调用接口的凭证:access_token
通过CorpID和Secret可以获得access_token
微信企业号接口调试地址: http://qydev.weixin.qq.com/debug
6、脚本放入的目录(该目录是zabbix自定义媒介告警脚本的目录)
将脚本放到zabbix默认执行的路径下
mv wechat.php wechat.sh /opt/zabbix/share/zabbix/alertscripts/
chown zabbix:zabbix /opt/zabbix/share/zabbix/alertscripts/wechat.php
chmod +x /opt/zabbix/share/zabbix/alertscripts/wechat.php
或
chown zabbix:zabbix /opt/zabbix/share/zabbix/alertscripts/wechat.sh
chmod +x /opt/zabbix/share/zabbix/alertscripts/wechat.sh
#设置脚本的启动用户为zabbix,并给脚本可执行权限
#修改zabbix_server.conf文件,添加脚本执行目录
AlertScriptsPath=/opt/zabbix/share/zabbix/alertscripts
#修改完成重启zabbix_server
/etc/init.d/zabbix_server restart
7、Pyhton微信告警脚本
#!/usr/bin/python
#_*_coding:utf-8_*_
importurllib,urllib2
import json
import sys
import simplejson
defgettoken(corpid,corpsecret):
gettoken_url ='https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=' + corpid +'&corpsecret=' + corpsecret
#print gettoken_url
try:
token_file =urllib2.urlopen(gettoken_url)
except urllib2.HTTPError as e:
print e.code
print e.read().decode("utf8")
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
defsenddata(access_token,user,subject,content):
send_url ='https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=' + access_token
send_values = {
"touser":user, #企业号中的用户帐号,在zabbix用户Media中配置,如果配置不正常,将按部门发送。
"toparty":"1", #企业号中的部门id。
"msgtype":"text", #消息类型。
"agentid":"1", #企业号中的应用id。
"text":{
"content":subject + '\n'+ content
},
"safe":"0"
}
# send_data = json.dumps(send_values,ensure_ascii=False)
send_data = simplejson.dumps(send_values,ensure_ascii=False).encode('utf-8')
send_request = urllib2.Request(send_url,send_data)
response =json.loads(urllib2.urlopen(send_request).read())
print str(response)
if __name__ =='__main__':
user = str(sys.argv[1]) #zabbix传过来的第一个参数
subject = str(sys.argv[2]) #zabbix传过来的第二个参数
#user = "shenkuan"
content = str(sys.argv[3]) #zabbix传过来的第三个参数
corpid = 'xxxxxxxxxxxxxxxxxxx' #CorpID是企业号的标识
corpsecret = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxx' #corpsecretSecret是管理组凭证密钥
accesstoken = gettoken(corpid,corpsecret)
senddata(accesstoken,user,subject,content)
8、Zabbix-web前端设置
8.1、设置通知媒介
8.2、创建用户(收件人可以写成@all,是给所有人)
8.3、创建触发动作及发送内容
告警主题:
Default subject:{TRIGGER.STATUS}: {TRIGGER.NAME}
Trigger host:{HOSTNAME}
Trigger ip:{HOST.IP}
Trigger time:{EVENT.DATE}:{EVENT.TIME}
Trigger: {TRIGGER.NAME}
Trigger status: {TRIGGER.STATUS}
Trigger severity: {TRIGGER.SEVERITY}
Trigger URL: {TRIGGER.URL}
Item values:
{ITEM.NAME1} ({HOST.NAME1}:{ITEM.KEY1}): {ITEM.VALUE1}
{ITEM.NAME2} ({HOST.NAME2}:{ITEM.KEY2}): {ITEM.VALUE2}
Original event ID: {EVENT.ID}
恢复主题:
Default subject:{TRIGGER.STATUS}: {TRIGGER.NAME}
Trigger host:{HOSTNAME}
Trigger ip:{HOST.IP}
Trigger time:{EVENT.DATE}:{EVENT.TIME}
Trigger: {TRIGGER.NAME}
Trigger status: {TRIGGER.STATUS}
Trigger severity: {TRIGGER.SEVERITY}
Trigger URL: {TRIGGER.URL}
Item values:
{ITEM.NAME1} ({HOST.NAME1}:{ITEM.KEY1}): {ITEM.VALUE1}
{ITEM.NAME2} ({HOST.NAME2}:{ITEM.KEY2}): {ITEM.VALUE2}
Original event ID: {EVENT.ID}
#设置完成记得新增或更新(add&update)
9、测试微信告警发送
#主动触发相关trigger告警,查看微信发送状态
#到此Zabbix-3.0.3结合微信告警完成。
10、注意事项及报错处理
#Zabbix-web页面新增用户权限处理,发送对象选择(应用ID)
#应用当中可见范围选择注意(选这要发送的对象(部门,及部门成员))
转发于https://www.oschina.net/news/75588/zabbix-3.0.3