一、注册微信企业号
因为订阅号的发送数量有限,很多时候超额发送之后会无法发送,现在我们申请企业号,因为企业号可以无限制的发送报警信息。
打开注册地址https://qy.weixin.qq.com/。
1、填写账号密码信息
2、邮箱激活
3、选择企业号
4、填写相关信息,注册成功
二、配置企业号
1、通讯录添加企业成员
我们要提前把成员信息添加进组织部门,必填项+手机号或者微信号,这样别人扫描二维码的时候才能成功关注企业号。
注意:这里有两个我们要用到信息,一个组织部门的ID,一个部门成员的账号(账号是自己手动指定的,不同于微信号,最好是字母加数字)
查看部门id,修改部门即可看到。
在部门添加新成员。
人员为扫描之前是?,扫描添加之后就正常了。
2、应用中心创建应用
我们要在这里创建应用,因为要通过应用发送消息给部门成员,可以创建多个,不同的业务通过不同的应用发送出去,我这里创建的是运维部,这里要记住一个值,应用ID,后面的发送脚本会用到。
3、给部门设置管理组
设置--->功能设置---->权限管理---->新建管理组,按照相应的信息设定好应用权限以及通讯录权限,里面的CorpID和Secret是我们后面脚本需要的。
三、调用微信接口
调用微信接口需要一个调用接口的凭证: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
1、编辑微信Python脚本
1
|
# cat /usr/local/zabbix/alertscripts/yunwei.py
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
#!/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、配置脚本权限
1
2
|
chown
zabbix.zabbix
/usr/local/zabbix/alertscripts/yunwei
.py
chmod
+x
/usr/local/zabbix/alertscripts/yunwei
.py
|
3、测试脚本
由脚本可以看出,我们不但可以使用zabbix报警,也可以使用任何shell报警。
1
2
|
[root@monitor alertscripts]
# python /usr/local/zabbix/alertscripts/yunwei.py test
{
"errcode"
:0,
"errmsg"
:
"ok"
}
|
可以看到可以正常的调用接口,我们接着配置zabbix。
四、配置Zabbix
1、创建媒介
2、给用户增加媒介
3、创建触发器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
======================================================
服务器:{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}
}
====================================================
|
Send only to选择我们设定的媒介。
3、测试
附录:Shell脚本
1、编辑微信Shell脚本
上面是Python的脚本,下面我贴一下Shell的脚本,其他的配置信息都是一样的,使用其中一个就可以了。
1
|
# cat /usr/local/zabbix/alertscripts/yunwei.sh
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
#!/bin/bash
#########################################################################
# File Name: yunwei_bash.sh
# Author: wzlinux
# Email: [email protected]
# 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
|
1
2
|
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"}
这里我不再进行截图了,我这边测试是通过的
本文转自 wzlinux 51CTO博客,原文链接:http://blog.51cto.com/wzlinux/1916772,如需转载请自行联系原作者
文章浏览阅读2w次,点赞7次,收藏51次。四个步骤1.创建C++ Win32项目动态库dll 2.在Win32项目动态库中添加 外部依赖项 lib头文件和lib库3.导出C接口4.c#调用c++动态库开始你的表演...①创建一个空白的解决方案,在解决方案中添加 Visual C++ , Win32 项目空白解决方案的创建:添加Visual C++ , Win32 项目这......_c#调用lib
文章浏览阅读4.6k次。苹方字体是苹果系统上的黑体,挺好看的。注重颜值的网站都会使用,例如知乎:font-family: -apple-system, BlinkMacSystemFont, Helvetica Neue, PingFang SC, Microsoft YaHei, Source Han Sans SC, Noto Sans CJK SC, W..._ubuntu pingfang
文章浏览阅读159次。表单表单概述表单标签表单域按钮控件demo表单标签表单标签基本语法结构<form action="处理数据程序的url地址“ method=”get|post“ name="表单名称”></form><!--action,当提交表单时,向何处发送表单中的数据,地址可以是相对地址也可以是绝对地址--><!--method将表单中的数据传送给服务器处理,get方式直接显示在url地址中,数据可以被缓存,且长度有限制;而post方式数据隐藏传输,_html表单的处理程序有那些
文章浏览阅读1.2k次。使用说明:开启Google的登陆二步验证(即Google Authenticator服务)后用户登陆时需要输入额外由手机客户端生成的一次性密码。实现Google Authenticator功能需要服务器端和客户端的支持。服务器端负责密钥的生成、验证一次性密码是否正确。客户端记录密钥后生成一次性密码。下载谷歌验证类库文件放到项目合适位置(我这边放在项目Vender下面)https://github.com/PHPGangsta/GoogleAuthenticatorPHP代码示例://引入谷_php otp 验证器
文章浏览阅读4.3k次,点赞5次,收藏11次。matplotlib.plot画图横坐标混乱及间隔处理_matplotlib更改横轴间距
文章浏览阅读2.2k次。①Storage driver 处理各镜像层及容器层的处理细节,实现了多层数据的堆叠,为用户 提供了多层数据合并后的统一视图②所有 Storage driver 都使用可堆叠图像层和写时复制(CoW)策略③docker info 命令可查看当系统上的 storage driver主要用于测试目的,不建议用于生成环境。_docker 保存容器
文章浏览阅读834次,点赞27次,收藏13次。网络拓扑结构是指计算机网络中各组件(如计算机、服务器、打印机、路由器、交换机等设备)及其连接线路在物理布局或逻辑构型上的排列形式。这种布局不仅描述了设备间的实际物理连接方式,也决定了数据在网络中流动的路径和方式。不同的网络拓扑结构影响着网络的性能、可靠性、可扩展性及管理维护的难易程度。_网络拓扑csdn
文章浏览阅读1.8k次,点赞5次,收藏8次。IOS系统Date的坑要创建一个指定时间的new Date对象时,通常的做法是:new Date("2020-09-21 11:11:00")这行代码在 PC 端和安卓端都是正常的,而在 iOS 端则会提示 Invalid Date 无效日期。在IOS年月日中间的横岗许换成斜杠,也就是new Date("2020/09/21 11:11:00")通常为了兼容IOS的这个坑,需要做一些额外的特殊处理,笔者在开发的时候经常会忘了兼容IOS系统。所以就想试着重写Date函数,一劳永逸,避免每次ne_date.prototype 将所有 ios
文章浏览阅读5.3k次。方法一:用PLSQL Developer工具。 1 在PLSQL Developer的sql window里输入select * from test for update; 2 按F8执行 3 打开锁, 再按一下加号. 鼠标点到第一列的列头,使全列成选中状态,然后粘贴,最后commit提交即可。(前提..._excel导入pl/sql
文章浏览阅读83次。Git常用命令速查手册1、初始化仓库git init2、将文件添加到仓库git add 文件名 # 将工作区的某个文件添加到暂存区 git add -u # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,不处理untracked的文件git add -A # 添加所有被tracked文件中被修改或删除的文件信息到暂存区,包括untracked的文件...
文章浏览阅读202次。分享119个ASP.NET源码总有一个是你想要的_千博二手车源码v2023 build 1120
文章浏览阅读1.8k次。版权声明:转载请注明出处 http://blog.csdn.net/irean_lau。目录(?)[+]1、缺省构造函数。2、缺省拷贝构造函数。3、 缺省析构函数。4、缺省赋值运算符。5、缺省取址运算符。6、 缺省取址运算符 const。[cpp] view plain copy_空类默认产生哪些类成员函数