搭建微信告警参考: https://www.abcdocker.com/abcdocker/2472
http://www.oschina.net/news/75588/zabbix-3.0.3
http://www.iyunv.com/thread-166308-1-1.html
微信告警的python脚本:
#!/usr/bin/python #_*_coding:utf-8 _*_ import urllib,urllib2 import json import sys import simplejson reload(sys) sys.setdefaultencoding(‘utf-8‘) def gettoken(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 def senddata(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":"2", #企业号中的部门id。 "msgtype":"text", #消息类型。 "agentid":"1000002", #企业号中的应用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传过来的第二个参数 content = str(sys.argv[3]) #zabbix传过来的第三个参数 corpid = ‘wxcf2f9418af480a23‘ #CorpID是企业号的标识 #corpsecret = ‘FOPk4InFyvHFdz6-_NjeZ9gHN1zJG‘ #corpsecretSecret是管理组凭证密钥 corpsecret = ‘aaYBYUACMMTWvIqdLLRnd-I7GMFIJMWBrZuCZ14lHiU‘ #corpsecretSecret是管理组凭证密钥 accesstoken = gettoken(corpid,corpsecret) senddata(accesstoken,user,subject,content) ## print accesstoken 打印访问的token,每次访问微信都会需要token,下面我需要找出部门ID所以打印token出来。
在上面的接收账号和部门ID我们全部写@all,就是发送给所有的人。我这样填写用来测试脚本是否可以发送信息。
测试:
root@H5MidServer:/usr/local/zabbix3/alertscripts# ./wechat.py 1 2 3 https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=wxcf2f9418af480a23&corpsecret=aaYBYUACMMTWvIqdLLRnd-I7GMFIJMWBrZuCZ14lHiU {u‘invaliduser‘: u‘‘, u‘errcode‘: 0, u‘errmsg‘: u‘ok‘}
经过上面的测试可以收到信息。还没有经过zabbix测试。
touser: 这里填的是企业微信通讯录的用户帐户,这里用user变量代替,这个值是在zabbix用户的告警媒介中配置的,通过zabbix传送给python脚本。
toparty: 这里是部门ID,合并后的企业微信在网页上的通讯录没有显示部门ID,后来经过查找,在官方文档中https://work.weixin.qq.com/api/doc#10093 这里有接口可以查询出部门的列表,所以需要用到上面打印出来的token,
在上面的代码中把token打印出来,然后根据token去获取部门ID,根据例子中的请求接口来获取部门ID
测试:
root@H5MidServer:/usr/local/zabbix3/alertscripts# curl -s -G https://qyapi.weixin.qq.com/cgi-bin/department/list?access_token=7z8kHkMNAEY-TBVgtXHX2K58-S8OTcISW6-_zxtO-xA8tNoSiv8q2PK-bUJfd9wK7A1N4sP2TnocQjKbHOENHTKDS9hv69g40l8r7_tF6K9xy16bD1sAmMY-G8UYQ49K9vC-quEgoKwOJ57bOFjIAUT4oxIiW10b8LcBXw4WkVINDyLjKdXu2mzZBcAWyIylaV85lVjd6G8hJTYBtE2B_ay5cmZwP7zxJtAFwTfpK8GJhNN2nm7IXGdTI4HiECLUqYJLzQpM-VBXmpNFit9stasokso0c8CAoYHnSi2GnX8 {"errcode":0,"errmsg":"ok","department":[{"id":2,"name":"运维组","parentid":1,"order":2147483447}]}
上面的接口返回显示了部门的ID了,然后后面的zabbix就是跟上面的资料一样操作了。
需要配置zabbix_server.conf文件中的告警脚本路径:
AlertScriptsPath=/usr/local/zabbix3/alertscripts
zabbix创建一个告警媒介
修改用户的告警媒介,用户的媒介中的收件人,写微信组里面的账号,如果错误则发给组内全部人。
还有配置--动作--Report problems to Zabbix administrators 动作中的配置也要改为微信告警。