作者:卢磊
博客:https://blog.csdn.net/qq_34556414
目录[-]
1、配置Zabbix微信报警媒介
2、配置收件人
3、配置Action
4、准备微信报警脚本
5、微信脚本关联企业微信
6、微信告警脚本配置连接微信API认证信息
7、企业微信消息测试
8、Zabbix告警测试
Zabbix没有为我们提供微信报警的媒介,我们需要自己创建,通过脚本来发消息。主要分为三部分:
-
zabbix server端配置报警媒介,以及发给谁 ;
-
准备微信告警脚本;
-
在企业微信创建应用API(供zabbix报警调用)以及用户的账号(收报警信息)。
1、配置Zabbix微信报警媒介
Administration-->Media Types-->Create Media Type
脚本加入三个参数:
-
{ALERT.SENDTO} 发送给谁
-
{ALERT.SUBJECT} 发送信息的标题
-
{ALERT.MESSAGE} 发送内容
脚本文件放在服务端即server端:微信脚本是放在服务端的weixin.sh
2、配置收件人
配置报警邮件的接收人,到底写谁?这个收件人必须拥有企业微信账号,后面会讲,可以先配置:
至此 发送端接收端都已经配置好了 微信监控报警配置完毕
3、配置Action
4、准备微信报警脚本
上传微信报警包,并解压缩 (公众号回复关键字:"zbx-wx" 即可获取)
[root@localhost src]# tar zxvf zabbix_weixin.x86_64.tar.gz
[root@localhost zabbix_weixin]# ll
total 6712
-rwxr-xr-x. 1 root wheel 6868856 Jan 27 2016 weixin #可以看到是一个可执行脚本文件,有x权限
-rw-r--r--. 1 root wheel 99 Jan 27 2016 weixincfg.json #配置文件
[root@localhost zabbix_weixin]# mv weixin weixin.sh #因为zabbix媒介weixin里面配置脚本名称就是weixin.sh,一个二进制文件(这个脚本名字要和媒介里面的微信脚本名称保持一致)
配置server端报警文件的路径,即脚本存放的路径:
[root@localhost zabbix_weixin]# vim /et
c/zabbix_server.conf
AlertScriptsPath=/var/lib/zabbixsrv/alertscripts
将脚本拷贝到该目录:
[root@localhost zabbixsrv]# mkdir -p /var/lib/zabbixsrv/alertscripts
[root@localhost ~]# cp /usr/src/zabbix_weixin/weixin.sh /var/lib/zabbixsrv/alertscripts/
[root@localhost ~]# cd /var/lib/zabbixsrv/alertscripts/
[root@localhost alertscripts]# ls
weixin.sh
[root@localhost alertscripts]# cp /usr/src/zabbix_weixin/weixincfg.json /etc/ --微信配置文件拷贝到/etc下面,这个文件配置在企业微信配置好后面配
5、微信脚本关联企业微信
在企业微信创建消息应用,在企业微信的后台创建应用,就是消息应用,微信报警的应用要绑定部门成员,只有在该部门里面的成员才可以接收到微信信息。
创建运维部门:
创建应用,这个应用就是用来实现报警的API, 可见范围就是哪些人可以使用该应用,即报警。
创建用户,这些用户属于运维部门,就是用来接收报警信息的,注意账号,这个账号是在zabbix配置收件人需要配置的,即send to。
6、企业微信消息测试
这个应用为报警提供了API接口,可以看到产生了AgentId Secret 这个都需要添加到配置文件里面,下面先来测试发信息。
可以看到通过该API可以向运维部的成员发送消息,要让zabbix触发器满足某个条件通过该API来实现微信报警。
7、微信告警脚本配置连接微信API认证信息
[root@localhost zabbix_weixin]# vim /etc/weixincfg.json
{
"corp": {
"corpid": "ww0ba7f12c8be29fdf",
"secret": "rDAdRGMdb5YilAWoChY5bJFCp1yS6t500i66LmoysDM",
"agentid": 1000004
}
}
这三行就是调用微信api接口凭据,copyid相当于企业ID, secret+agentid相当于一个应用,这个应用就是来实现报警的。
8、Zabbix告警测试
找一台被监控端,关闭nginx服务触发告警。
- END -