首页 > 代码库 > zabbix 微信告警

zabbix 微信告警

搭建微信告警参考:  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 = http://www.mamicode.com/json.dumps(send_values, ensure_ascii=False)
    send_data = http://www.mamicode.com/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
{uinvaliduser: u‘‘, uerrcode: 0, uerrmsg: uok}

经过上面的测试可以收到信息。还没有经过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 动作中的配置也要改为微信告警。

技术分享

 

zabbix 微信告警