查看微信订阅号监控请点击


一、注册微信企业号

    因为订阅号的发送数量有限,很多时候超额发送之后会无法发送,现在我们申请企业号,因为企业号可以无限制的发送报警信息。

   打开注册地址https://qy.weixin.qq.com/

1、填写账号密码信息

wKiom1j0eJDwJZe-AACORP-_FXg249.jpg

2、邮箱激活

wKioL1j0eM7C7-lMAABpfcEd3GM333.jpg


wKiom1j0eM6guZwbAAEHOxr-eUw226.jpg

3、选择企业号

wKiom1j0ePqCnkaEAAEiJ30emfk131.jpg

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

wKiom1j0eRfgg8nmAAD9fsCweaI468.jpg


二、配置企业号

1、通讯录添加企业成员
    我们要提前把成员信息添加进组织部门,必填项+手机号或者微信号,这样别人扫描二维码的时候才能成功关注企业号。

   注意:这里有两个我们要用到信息,一个组织部门的ID,一个部门成员的账号(账号是自己手动指定的,不同于微信号,最好是字母加数字)

wKiom1j0lV-D_2ZmAAAdNelLeXs712.jpg

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

wKiom1j0lX6gxDbUAAAvWFW1Cdk712.jpg

   在部门添加新成员。

wKioL1j0fwXRgQ_fAACHCSM7H14812.jpg

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

wKiom1j0fwbikQwMAACXz1Xpi5A615.jpg


2、应用中心创建应用

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

wKioL1j0g-ChlH4ZAABlFqQ8R0U367.jpg


wKioL1j0g_vR-7WYAABn19DdX9w404.jpg


wKioL1j0hEfRRxtBAABJla3rVNE149.jpg

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

wKioL1j0hhqiB6t3AACZxfiEw0o785.jpg

三、调用微信接口

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

wKiom1kME8jzDUD1AABVgGFX408811.jpgwKioL1kME8nzKmrvAAD7tYzgfJI429.jpg

1、编辑微信Python脚本

# cat /usr/local/zabbix/alertscripts/yunwei.py
#!/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、配置脚本权限

chown zabbix.zabbix /usr/local/zabbix/alertscripts/yunwei.py
chmod +x /usr/local/zabbix/alertscripts/yunwei.py

3、测试脚本

    由脚本可以看出,我们不但可以使用zabbix报警,也可以使用任何shell报警。

[root@monitor alertscripts]# python /usr/local/zabbix/alertscripts/yunwei.py test
{"errcode":0,"errmsg":"ok"}

wKiom1j0lEzCPBcrAAFDY8nYGSY313.png

    可以看到可以正常的调用接口,我们接着配置zabbix。


四、配置Zabbix

1、创建媒介

wKiom1kvxUqSPpDgAACdP5OrI0o393.jpg

2、给用户增加媒介

wKiom1j0l4jSzjKvAADFwjre0Js512.jpg

wKioL1j0l3mBG2AOAABXnQjIlKU741.jpg

3、创建触发器

wKiom1kvxcmjGNxRAAEvMDhobnQ793.jpg

======================================================
服务器:{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}
}
====================================================

wKioL1j0mm3D-gn8AAD8l9F3oZg284.jpg

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

wKiom1j0mm7QxQkxAAFY3oPrZZM517.jpg

3、测试

wKiom1kvxf_i2KFlAANZEkAUdPU679.png



附录:Shell脚本

1、编辑微信Shell脚本

    上面是Python的脚本,下面我贴一下Shell的脚本,其他的配置信息都是一样的,使用其中一个就可以了。

# cat /usr/local/zabbix/alertscripts/yunwei.sh
#!/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
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"}

这里我不再进行截图了,我这边测试是通过的





                               wKioL1j0nZTDtjQ-AACmb4CVfN4005.jpg