zabbix模板的自动发现规则(ldd)实现被监控项自动发现
自动发现规则(ldd)用途说明
在zabbix自带的linux模板的自动发现规则中,有一个Mounted filesystem discovery自动发现规则,可以根据每个服务器磁盘梳理不同,自动生成相应的磁盘监控数据. 这就是自动注册的用途,根据不同服务器上同一个监控项不同的数量,自动生成对应数量的监控
例如5个服务器都分别启动了tomcat多实例,但启动的tomcat数量不相同,端口也不同,我想要监控这些端口是否down掉: 用普通的方式创建的监控模板,就得给每个服务器单独创建,不能通用 而如果通过自动发现规则来创建,就可以只用一个模板,对应这些不同数量的tomcat进行端口检查
自动发现规则使用实例
以监控java端口的自动发现为例,进行操作说明 流程:
命令行获取结果
编写zabbix脚本,输出json格式
创建zabbix客户端key
服务端验证结果
web页添加模板规则
web页主机绑定模板
验证结果
1. 命令行获取结果
首先在命令行,使用命令获取想要的结果
[root@zhimai-api02 api]# ss -lntup|grep java|awk -F "[ |:]+" '{print $6}'
9090
9091
2. 编写zabbix脚本,输出json格式
zabbix的api需要的都是json格式的数据,这里也不例外,不管通过shell脚本还是python脚本,反正最终需要输出json格式数据 shell脚本如下: vim java_port_list.sh
#!/bin/bash
#获取所有java服务端口,并以json格式返回
string=`ss -l