首页 > 其他分享 >Zabbix5.0微信报警

Zabbix5.0微信报警

时间:2022-12-15 17:01:39浏览次数:77  
标签:Zabbix5.0 Token 微信 报警 zabbix json controlnode root Secret

3.1、注测企业微信:

Zabbix5.0微信报警_企业号


3.2、企业微信注册成功后进入后台管理:

Zabbix5.0微信报警_企业号_02


3.3、添加一个部门,并记住部门id:

#我这里添加的子部门ID为2

Zabbix5.0微信报警_json_03


3.4、添加一个用户到上面创建的部门里面(这里采取直接将管理员添加进去):

1、

Zabbix5.0微信报警_Data_04


2、

Zabbix5.0微信报警_json_05


3、记住用户账号:

#帐号:LiuChang

Zabbix5.0微信报警_Data_06


3.5、创建一个自建应用:

1、

Zabbix5.0微信报警_json_07


2、

Zabbix5.0微信报警_企业号_08


3、创建完成记住AgentID和Secret:

#AgentId 1000002

#Secret 2R7fvRNuSK8grwtVFBC_O_qfje3gyIKZE0MS_nPCwbc

Zabbix5.0微信报警_Data_09


3.6、记住企业ID:

#企业ID ww6922bb251acfe899

Zabbix5.0微信报警_json_10

到这里上面的企业微信注册就完成了,记住上面所提到需要记住的。


3.7、微信企业号接口调试工具:

​http://qydev.weixin.qq.com/debug​

Zabbix5.0微信报警_企业号_11


3.8、查看zabbix-server脚本存放的位置:

[root@controlnode ~]# grep ^AlertScriptsPath /etc/zabbix/zabbix_server.conf

AlertScriptsPath=/usr/lib/zabbix/alertscripts


3.9、安装requests组件:

[root@controlnode ~]# yum install python-pip

[root@controlnode ~]# pip install --upgrade pip

[root@controlnode ~]# pip install requests


3.10、下载微信脚本:

[root@controlnode ~]# mkdir -p /tools/

[root@controlnode ~]# cd /tools/

[root@controlnode tools]# git clone https://github.com/X-Mars/Zabbix-Alert-WeChat.git

[root@controlnode tools]# cp -a Zabbix-Alert-WeChat/wechat.py /usr/lib/zabbix/alertscripts/

[root@controlnode tools]# cd /usr/lib/zabbix/alertscripts/

[root@controlnode alertscripts]# chmod +x wechat.py

[root@controlnode alertscripts]# cat wechat.py

#脚本原始配置如下

#!/usr/bin/python
#-*- coding: utf-8 -*-
#zabbix微信报警

import requests,sys,json
import urllib3
urllib3.disable_warnings()

reload(sys)
sys.setdefaultencoding('utf-8')

def GetTokenFromServer(Corpid,Secret):
Url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
Data = {
"corpid":Corpid,
"corpsecret":Secret
}
r = requests.get(url=Url,params=Data,verify=False)
print(r.json())
if r.json()['errcode'] != 0:
return False
else:
Token = r.json()['access_token']
file = open('/tmp/zabbix_wechat_config.json', 'w')
file.write(r.text)
file.close()
return Token

def SendMessage(User,Agentid,Subject,Content):
try:
file = open('/tmp/zabbix_wechat_config.json', 'r')
Token = json.load(file)['access_token']
file.close()
except:
Token = GetTokenFromServer(Corpid, Secret)

n = 0
Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
Data = {
"touser": User, # 企业号中的用户帐号,在zabbix用户Media中配置,如果配置不正常,将按部门发送。
#"totag": Tagid, # 企业号中的标签id,群发使用(推荐)
#"toparty": Partyid, # 企业号中的部门id,群发时使用。
"msgtype": "text", # 消息类型。
"agentid": Agentid, # 企业号中的应用id。
"text": {
"content": Subject + '\n' + Content
},
"safe": "0"
}
r = requests.post(url=Url,data=json.dumps(Data),verify=False)
while r.json()['errcode'] != 0 and n < 4:
n+=1
Token = GetTokenFromServer(Corpid, Secret)
if Token:
Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
r = requests.post(url=Url,data=json.dumps(Data),verify=False)
print(r.json())

return r.json()


if __name__ == '__main__':
User = sys.argv[1] # zabbix传过来的第一个参数
Subject = str(sys.argv[2]) # zabbix传过来的第二个参数
Content = str(sys.argv[3]) # zabbix传过来的第三个参数

Corpid = "wxaf" # CorpID是企业号的标识
Secret = "aKDdCRT76" # Secret是管理组凭证密钥
#Tagid = "1" # 通讯录标签ID
Agentid = "1000001" # 应用ID
#Partyid = "1" # 部门ID

Status = SendMessage(User,Agentid,Subject,Content)
print Status


3.11、根据脚本里面的注释进行相应的修改,改成自己企业微信号中的信息,如下:

[root@controlnode alertscripts]# cat wechat.py 
#!/usr/bin/python
#-*- coding: utf-8 -*-
#zabbix微信报警

import requests,sys,json
import urllib3
urllib3.disable_warnings()

reload(sys)
sys.setdefaultencoding('utf-8')

def GetTokenFromServer(Corpid,Secret):
Url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken"
Data = {
"corpid":Corpid,
"corpsecret":Secret
}
r = requests.get(url=Url,params=Data,verify=False)
print(r.json())
if r.json()['errcode'] != 0:
return False
else:
Token = r.json()['access_token']
file = open('/tmp/zabbix_wechat_config.json', 'w')
file.write(r.text)
file.close()
return Token

def SendMessage(User,Agentid,Subject,Content):
try:
file = open('/tmp/zabbix_wechat_config.json', 'r')
Token = json.load(file)['access_token']
file.close()
except:
Token = GetTokenFromServer(Corpid, Secret)

n = 0
Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
Data = {
"touser": "LiuChang", # 企业号中的用户帐号,在zabbix用户Media中配置,如果配置不正常,将按部门发送。
#"totag": Tagid, # 企业号中的标签id,群发使用(推荐)
"toparty": "2", # 企业号中的部门id,群发时使用。
"msgtype": "text", # 消息类型。
"agentid": "1000002", # 企业号中的应用id。
"text": {
"content": Subject + '\n' + Content
},
"safe": "0"
}
r = requests.post(url=Url,data=json.dumps(Data),verify=False)
while r.json()['errcode'] != 0 and n < 4:
n+=1
Token = GetTokenFromServer(Corpid, Secret)
if Token:
Url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=%s" % Token
r = requests.post(url=Url,data=json.dumps(Data),verify=False)
print(r.json())

return r.json()


if __name__ == '__main__':
User = sys.argv[1] # zabbix传过来的第一个参数
Subject = str(sys.argv[2]) # zabbix传过来的第二个参数
Content = str(sys.argv[3]) # zabbix传过来的第三个参数

Corpid = "ww6922bb251acfe899" # CorpID是企业号的标识
Secret = "2R7fvRNuSK8grwtVFBC_O_qfje3gyIKZE0MS_nPCwbc" # Secret是管理组凭证密钥
#Tagid = "1" # 通讯录标签ID
Agentid = "1000002" # 应用ID
Partyid = "2" # 部门ID

Status = SendMessage(User,Agentid,Subject,Content)
print Status


3.12、测试:

1、执行脚本:

[root@controlnode alertscripts]# ./wechat.py LiuChang Title_test "这是测试信息,请忽略"

Zabbix5.0微信报警_Data_12

参数说明:

LiuChang:表示新建部门下的用户账号。

Title_test:表示发送的报警信息的标题。

"这是测试信息,请忽略":发送的报警信息的具体内容。


2、手机登陆到上面自己创建的企业微信,可查看到报警信息:

Zabbix5.0微信报警_企业号_13


3.13、在zabbix web界面中配置微信报警:

1、进入:管理 -> 报警媒介类型 -> 创建媒体类型:

脚本参数

{ALERT.SENDTO}

{ALERT.SUBJECT}

{ALERT.MESSAGE}

Zabbix5.0微信报警_Data_14


2、进入:配置-> 动作 -> Report problems to Zabbix administrators 创建动作,这里省略,具体看

上一篇文章"2、Zabbix5.0钉钉报警":


3、进入:管理->用户->报警媒介(这里收件人对应企业微信号中的应用ID):

Zabbix5.0微信报警_企业号_15


3.14、报警测试:

1、停止nginx服务:

[root@controlnode alertscripts]# systemctl stop nginx

Zabbix5.0微信报警_企业号_16


2、启动ngnix服务:

[root@controlnode alertscripts]# systemctl start nginx

Zabbix5.0微信报警_json_17






标签:Zabbix5.0,Token,微信,报警,zabbix,json,controlnode,root,Secret
From: https://blog.51cto.com/u_11409186/5940305

相关文章

  • 微信二维码名片不显示头像 微信二维码怎么恢复原来的样式
    新版本的微信更新之后,微信的个人名片二维码中间不是自己的头像了。而且二维码的识别率也没有之前的高了!好多年朋友在问微信二维码怎么换成以前那种中间带头像的?想应该如何......
  • 微信公众号开发
     现在微信越来越热门,大量的公众号涌现,为我们生活带来不少便利。让我们来了解一下这个公众号是怎么出来的。 一.申请域名服务器以前部署一个网站得准备硬件,申请域名,这对于......
  • 微信协议简单调研笔记
    前言微信可调研点很多,这里仅仅从协议角度进行调研,会涉及到微信协议交换、消息收发等。所谓“弱水三千,只取一瓢”吧。杂七杂八的,有些长,可直接拉到最后看结论好了。一。微信协......
  • 浏览器打开微信小程序
    functionh5(){ $wx=newWx('appId','appSecret'); //\dump($wx->getAccessToken()); $url='https://api.weixin.qq.com/wxa/generatescheme?'.\http_build_qu......
  • 微信授权登录
    公司的业务需求,对接了微信公众号授权,通过微信公众号的接口拿到用户信息进行业务系统的登录,话不多说上代码/***公众号登录*@paramcode授权码*@ret......
  • #yyds干货盘点#【愚公系列】2022年12月 微信小程序-图片加载和全屏适配问题
    前言在使用图片问题中可能会遇到各种各样的问题,比如图片加载不出来,图片显示在不同机型效果不同,图片加载展示问题等等。微信小程序image相关属性如下:属性类型默认值......
  • 搭建ogg双向复制时,oracle 19.16向oracle 10.2.0.4 ogg复制时报警OGG-01389、OGG-02246
    文档课题:搭建ogg双向复制时,oracle19.16向oracle10.2.0.4ogg复制时报警OGG-01389、OGG-02246处理记录.源端:IP192.168.133.103数据库oracle11.2.0.464位,实例名:or......
  • 监控报警体系:Prometheus和Grafana
    总体prometheus全链路监控报警,在当今云原生时代可观测领域,Prometheus + Grafana 成为可观测性事实标准。采集数据:运维团队可以使用 Prometheus 监控云原生 Kub......
  • 记录--uniapp 应用APP跳转微信小程序
    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助最近APP项目开发完成,在评审会上老板提了一个需求,想在开发的APP上添加一个链接,可以跳转公司的小程序商城。......
  • 微信小程序项目之失物招领平台-2.lostanfound页面的编写
    1.在lostandfound.js中添加需要的数据//pages/lostandfound/lostandfound.jsPage({/***页面的初始数据*/data:{tabs1:[{......