使用Zabbix Api功能,跨互联网 监控Zabbix-Proxy状态

背景

项目需要通过zabbix-proxy 来获取监控数据【网络是单向的,zabbix-proxy 通过公网主动连接 zabbix-server ,上报监控数据,已达到监控的目的】

需求

因为是单向网络,proxy 挂了后,zabbix master 都无法获取到 zabbix-proxy 和 下面的agent 机器的离线的状态,更不会触发告警;现需要对 zabbix-proxy 的状态实行监控,利用 zabbix-proxy 主动上传到 zabbix 页面上的 agent 代理程序的 状态 来判断 zabbix-proxy 的存活

使用Zabbix Api功能,跨互联网 监控Zabbix-Proxy状态

思路

通过获取 zabbix api 中 Proxy 代理 的 信息 来实现 监控

官方api说明:

版本:zabbix4.0

获取token:https://www.zabbix.com/documentation/4.0/zh/manual/api/reference/user/login

获取proxy 代理信息: https://www.zabbix.com/documentation/4.0/zh/manual/api/reference/proxy/get

#获取token:

#入参:
curl -s -X POST -H 'Content-Type: application/json' -d '
{
    "jsonrpc": "2.0",
    "method": "user.login",
    "params": {
        "user": "Admin",
        "password": "PASSWORD"
    },
    "id": 1
}' http://172.16.10.37:8888/api_jsonrpc.php;

#回参:
{"jsonrpc":"2.0","result":"为0qwewerwrsdfdsfdsafsd","id":1}

#得到token 为0qwewerwrsdfdsfdsafsd

#获取proxy 代理信息

#利用上面获取的token,来获取api 中proxy 的代理信息

#入参:
curl -s -X POST -H 'Content-Type: application/json' -d '
{
    "jsonrpc": "2.0",
    "method": "proxy.get",
    "params": {
        "output": "extend",
        "selectInterface": "extend"
    },
    "auth": "0qwewerwrsdfdsfdsafsd",
    "id": 1
}' http://172.16.10.37:8888/api_jsonrpc.php


#回参
{
	"jsonrpc": "2.0",
	"result": [
		{
			"proxy_hostid": "0",
			"host": "a-proxy",
			"status": "5",
			"disable_until": "0",
			"error": "",
			"available": "0",
			"errors_from": "0",
			"lastaccess": "1637806905",
			"ipmi_authtype": "-1",
			"ipmi_privilege": "2",
			"ipmi_username": "",
			"ipmi_password": "",
			"ipmi_disable_until": "0",
			"ipmi_available": "0",
			"snmp_disable_until": "0",
			"snmp_available": "0",
			"maintenanceid": "0",
			"maintenance_status": "0",
			"maintenance_type": "0",
			"maintenance_from": "0",
			"ipmi_errors_from": "0",
			"snmp_errors_from": "0",
			"ipmi_error": "",
			"snmp_error": "",
			"jmx_disable_until": "0",
			"jmx_available": "0",
			"jmx_errors_from": "0",
			"jmx_error": "",
			"name": "",
			"flags": "0",
			"templateid": "0",
			"description": "a-proxy",
			"tls_connect": "1",
			"tls_accept": "1",
			"tls_issuer": "",
			"tls_subject": "",
			"tls_psk_identity": "",
			"tls_psk": "",
			"proxy_address": "1.1.1.1",
			"auto_compress": "1",
			"discover": "0",
			"proxyid": "10385",
			"interface": []
		},
		{
			"proxy_hostid": "0",
			"host": "b-proxy",
			"status": "5",
			"disable_until": "0",
			"error": "",
			"available": "0",
			"errors_from": "0",
			"lastaccess": "1637806906",
			"ipmi_authtype": "-1",
			"ipmi_privilege": "2",
			"ipmi_username": "",
			"ipmi_password": "",
			"ipmi_disable_until": "0",
			"ipmi_available": "0",
			"snmp_disable_until": "0",
			"snmp_available": "0",
			"maintenanceid": "0",
			"maintenance_status": "0",
			"maintenance_type": "0",
			"maintenance_from": "0",
			"ipmi_errors_from": "0",
			"snmp_errors_from": "0",
			"ipmi_error": "",
			"snmp_error": "",
			"jmx_disable_until": "0",
			"jmx_available": "0",
			"jmx_errors_from": "0",
			"jmx_error": "",
			"name": "",
			"flags": "0",
			"templateid": "0",
			"description": "b-proxy",
			"tls_connect": "1",
			"tls_accept": "1",
			"tls_issuer": "",
			"tls_subject": "",
			"tls_psk_identity": "",
			"tls_psk": "",
			"proxy_address": "1.1.1.1",
			"auto_compress": "1",
			"discover": "0",
			"proxyid": "10402",
			"interface": []
		},
		{
			"proxy_hostid": "0",
			"host": "c_proxy",
			"status": "5",
			"disable_until": "0",
			"error": "",
			"available": "0",
			"errors_from": "0",
			"lastaccess": "1637806905",
			"ipmi_authtype": "-1",
			"ipmi_privilege": "2",
			"ipmi_username": "",
			"ipmi_password": "",
			"ipmi_disable_until": "0",
			"ipmi_available": "0",
			"snmp_disable_until": "0",
			"snmp_available": "0",
			"maintenanceid": "0",
			"maintenance_status": "0",
			"maintenance_type": "0",
			"maintenance_from": "0",
			"ipmi_errors_from": "0",
			"snmp_errors_from": "0",
			"ipmi_error": "",
			"snmp_error": "",
			"jmx_disable_until": "0",
			"jmx_available": "0",
			"jmx_errors_from": "0",
			"jmx_error": "",
			"name": "",
			"flags": "0",
			"templateid": "0",
			"description": "c_proxy",
			"tls_connect": "1",
			"tls_accept": "1",
			"tls_issuer": "",
			"tls_subject": "",
			"tls_psk_identity": "",
			"tls_psk": "",
			"proxy_address": "1.1.1.1",
			"auto_compress": "1",
			"discover": "0",
			"proxyid": "10445",
			"interface": []
		}
	],
	"id": 1
}

再次过滤,找到lastaccess字段,该字段的值表示 proxy 当前的 时间戳,每5秒 内会发生变化;通过对比该字段的值 和 zabbix-server 当前时间戳的 时间差,来判断 proxy 的状态是否正常


添加监控项:

获取 lastaccess字段 的值

创建监控脚本:

[root@sre ~]# cd /etc/zabbix/zabbix_agentd.d

[root@sre zabbix_agentd.d]#  vim a-proxy-check.sh
#!/bin/bash
curl -s -X POST -H 'Content-Type: application/json' -d '
{
    "jsonrpc": "2.0",
    "method": "proxy.get",
    "params": {
        "output": "extend",
        "selectInterface": "extend"
    },
    "auth": "0qwewerwrsdfdsfdsafsd",
    "id": 1
}' http://172.16.10.37:8888/api_jsonrpc.php | awk -F '{"' '{print $3}' | awk -F ',' '{print $8}' | awk -F '"' '{print $4}'


[root@sre zabbix_agentd.d]# chmod +x /etc/zabbix/zabbix_agentd.d/a-proxy-check.sh

修改 zabbix_agentd.conf 配置文件,创建KEY ,指定脚本路径

[root@sre ~]# vim /etc/zabbix/zabbix_agentd.conf 
........
UnsafeUserParameters=1
#自定义一个key,监控a_proxy的状态
UserParameter=a_proxy_status,/bin/bash /etc/zabbix/zabbix_agentd.d/a-proxy-check.sh
........

重启 zabbix-agent

 systemctl restart zabbix-agent

登录到zabbix-server 使用zabbix-get 测试监控项

[root@sre zabbix]# zabbix_get -s 172.16.10.37 -p 10050 -k "a_proxy_status"
1637923240

登录到zabbix web 控制台,

#添加监控项

使用Zabbix Api功能,跨互联网 监控Zabbix-Proxy状态

#添加触发器

触发器表达式表示: 当a-proxy 时间戳的 值 和 zabbix 当前时间戳的值 ,相差60 秒 ,触发告警

使用Zabbix Api功能,跨互联网 监控Zabbix-Proxy状态

修改触发器值,模拟触发告警

使用Zabbix Api功能,跨互联网 监控Zabbix-Proxy状态

总结: 本篇文能写出来也是被逼无奈,单向网络,跨互联网监控,也是生产上一个案例吧,作者能力有限,欢迎大家~多多评论~交流

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
安装 Zabbix Proxy 需要以下步骤: 1. 安装 Zabbix Proxy 的依赖包: ``` sudo apt-get install fping libcurl4-openssl-dev libiksemel-dev libxml2-dev libsnmp-dev python-dev ``` 2. 下载 Zabbix Proxy 的源码包: ``` wget https://cdn.zabbix.com/zabbix/sources/stable/5.0/zabbix-5.0.1.tar.gz ``` 3. 解压源码包: ``` tar -zxvf zabbix-5.0.1.tar.gz ``` 4. 进入解压后的目录: ``` cd zabbix-5.0.1 ``` 5. 编译并安装 Zabbix Proxy: ``` ./configure --enable-proxy --prefix=/usr/local/zabbix-proxy make install ``` 6. 创建 Zabbix Proxy 的日志文件和运行用户: ``` sudo mkdir /var/log/zabbix-proxy sudo chown zabbix:zabbix /var/log/zabbix-proxy sudo useradd -r -s /usr/sbin/nologin zabbix ``` 7. 配置 Zabbix Proxy: 编辑 `/usr/local/zabbix-proxy/etc/zabbix_proxy.conf` 文件: ``` Server=<Zabbix Server IP> Hostname=<Hostname of Zabbix Proxy> LogFile=/var/log/zabbix-proxy/zabbix_proxy.log LogFileSize=0 PidFile=/var/run/zabbix/zabbix_proxy.pid DBName=<Zabbix database name> DBUser=<Zabbix database username> DBPassword=<Zabbix database password> DBHost=<Zabbix database host> DBPort=<Zabbix database port> ProxyMode=0 ProxyLocalBuffer=0 HeartbeatFrequency=60 ConfigFrequency=3600 DataSenderFrequency=1 StartPollers=5 ``` 注意:将 `<Zabbix Server IP>`、`<Hostname of Zabbix Proxy>`、`<Zabbix database name>`、`<Zabbix database username>`、`<Zabbix database password>`、`<Zabbix database host>`、`<Zabbix database port>` 替换为你自己的配置。 8. 启动 Zabbix Proxy: ``` sudo /usr/local/zabbix-proxy/sbin/zabbix_proxy -c /usr/local/zabbix-proxy/etc/zabbix_proxy.conf ``` 9. 设置 Zabbix Proxy 开机自启动: 编辑 `/etc/systemd/system/zabbix-proxy.service` 文件: ``` [Unit] Description=Zabbix Proxy After=syslog.target network.target [Service] User=zabbix Group=zabbix ExecStart=/usr/local/zabbix-proxy/sbin/zabbix_proxy -c /usr/local/zabbix-proxy/etc/zabbix_proxy.conf Restart=on-failure [Install] WantedBy=multi-user.target ``` 保存并退出。 10. 重新加载 systemd 配置,并启动 Zabbix Proxy 服务: ``` sudo systemctl daemon-reload sudo systemctl start zabbix-proxy sudo systemctl enable zabbix-proxy ``` 现在你已经成功安装了 Zabbix Proxy,并启动了服务,可以使用 Zabbix Server 进行监控了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值