php及时获取zabbix告警,zabbix实现状态码情况之微信告警

zabbix实现状态码情况之微信告警

zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。

zabbix由2部分构成,zabbix server与可选组件zabbix agent。

zabbix server可以通过SNMP,zabbix agent,ping,端口监视等方法提供对远程服务器/网络状态的监视,数据收集等功能,它可以运行在Linux,Solaris,HP-UX,AIX,Free BSD,Open BSD,OS X等平台上。即数据的采集方式有两种:

公用协议专用:(SNMP SSH Telnet)无agent,不需要去安装额外的agent

专用客户端采集:zabbix agent来完成数据采集工作

下面采用C/P/S架构实现:

在搭建zabbix这块就不详细介绍了,我这边大概描述下:

一、安装server端

1、首先在server端安装一个网络yum包:

rpm  -ivh  http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm

2、安装zabbix server端:监控端

yum install -y zabbix-server-mysql zabbix-web-mysql

3、安装数据库:mariadb

yum groupinstall -y mariadb mariadb-client

4、修改mariadb配置文件

vim /etc/my.cnf

character-set-server=utf8 #设置字符集为utf8

innodb_file_per_table=1   #让innodb的每个表文件单独存储

5、将mariadb服务开机自动启动和重启服务:

systemctl enable mariadb

systemctl restart mariadb

执行安全操作:

mysql_secure_installation

mysql -uroot -predhat

创建数据库zabbix,授权给用户zabbix访问本地数据库:

a、MariaDB [(none)]> create database zabbix character set utf8 collate utf8_bin;

b、MariaDB [(none)]> grant all privileges on zabbix.* to zabbix@localhost identified by 'zabbix';

c、MariaDB [(none)]> flush privileges;

在数据库里面导入表:

cd /usr/share/doc/zabbix-server-mysql-3.2.1/

解压缩:gzip -d create.sql.gz

mv /usr/share/doc/zabbix-server-mysql-3.2.1/create.sql /root

746b5203a4eaebd780603938dcd7f958.png

登录zabbix数据库:mysql -uzabbix -pzabbix zabbix

将create.sql表导入数据库:source create.sql

6、配置文件vim /etc/zabbix/zabbix_server.conf

DBPassword=zabbix

7、重启服务(使用rhel7.2,不然7.0要升级)

systemctl enable zabbix-server.service

systemctl restart zabbix-server.service

8、PHP:在配置文件修改时区

d9c4e87c5629566a9c7d43ec43b04950.png

重启http服务:

systemctl restart httpd

9、实验的验证:http://172.25.254.132/zabbix

注意:防火墙这边我都没设置,故可以直接关闭防火墙和关闭selinux

cd18caafaa53bc22f9529276e7e7e6f1.png

11cf1fcb24501fe1d6e11537c839e50b.png

二、安装客户端(zabbix-agent):

1、在agent端上安装网络yum源包:

rpm -ivh http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/zabbix-release-3.2-1.el7.noarch.rpm

2、安装监控主机zabbix-agent

a、yum install -y zabbix-agent

b、要修改好配置文件之后才启动服务。

vim /etc/zabbix/zabbix_agentd.conf    配置文件

Server=172.25.254.132                监控的服务器是谁!

Hostname=chen                       监控主机:hostname最左边的字段

systemctl restart zabbix-agent.service  配置改完重启服务

3、创建主机

9536ed6fee8b332fa0337ea6915f2833.png

ee3db4a450623c0969a53077f0fdd6cd.png

4、对zabbix-get命令简单的测试

在server端安装zabbix-get包!

yum install -y zabbix-get

zabbix_get --help

zabbix_get -s 172.25.254.133 -k system.hostname

11e70ad96cd5ad5b70182947e5a82939.png

zabbix_get -s 172.25.254.131 -k system.cpu.util[0,user,avg5]

4bdc7623c7650b92c7a0f06afde84aaf.png

三、接下来直入主题

首先,添加报警媒介、用户,

cd161930f62a975bf9d78010e127642a.png

微信告警脚本如下:

CropID='xxxxxxxxxxx'

Secret='xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'

GURL="https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid=$CropID&corpsecret=$Secret"

Gtoken=$(/usr/bin/curl  $GURL -H "DNT: 1" -H "Accept-Encoding: gzip, deflate" -H "Accept-Language: zh-CN,zh;q=0.8" -H "User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.135 BIDUBrowser/8.1 Safari/537.36" -H "Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8" -H "X-DevTools-Emulate-Network-Conditions-Client-Id: B546FC80-414C-403F-95F0-EB0F70E58EF7" -H "Connection: keep-alive" -H "Cache-Control: max-age=0" --compressed | awk -F \" '{print $10}')

PURL="https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=$Gtoken"

function body() {

local int AppID=1                       # 企业号中的应用id

local UserID=$1                         # 部门成员id,zabbix中定义的微信接收者

local PartyID=2                         # 部门id,定义了范围,组内成员都可接收到消息

local Msg=$(echo "$@" | cut -d" " -f3-) # 过滤出zabbix中传递的第三个参数

printf '{\n'

printf '\t"touser": "'"$User"\"",\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

然后,在主机中添加监控项

b1dd5185409d9c4b92a803675219a68d.png

自己定义监控项监控curl状态码的情况

057d4e0f437ec09a8d4fa2d1a3869c02.png

其次,Trigger设置4步曲:

只要trigger状态发生变化,就会伴随事件的发生,随之也会有相应action

1、设置Trigger

2、配置用户

3、配置告警介质

4、设置Action

aba2dee76ac3ee6c8ab924092a53de55.png

接着,添加action的步骤:

a、user/group:发送消息的媒介

b、报警媒介类型

c、action

3848da363ab6408d6db86ad30aa6f844.png

1aec65c4da90cde1a1fc5b6f91002f1e.png

501d3edd188f3ea3ba381d2efb650b21.png

到这步已经基本完成。接下来就是监测页面的触发器了

028ee0615194cf471fb36f556370e73a.png

状态码出现变化,便会发送微信告警!!!

1、假如出现宕机,便会触发,并微信告警

60ad7324cfeef9628fb51e78c03ed8e2.png

5166038439a6a11784b81e845dc917da.png

8a12c5a9e05c91b2e51b67efb0db59b0.png

2、恢复状态时,也会发送微信信息

318854fcba3fa11d39712cbbf1d3ec96.png

6453a339cee03926ac0c6724a8bfa807.png

4828f7c8b04e46bbe34e108e7867a44e.png

9e288becce0ed2e766426e5eff3c5d58.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值