Zabbix批量添加端口监控

我们在监控生产环境的服务的时候,通常需要对多个端口进行监控,如果我们手动的一个一个的添加,这回让我们崩溃,所以批量添加端口监控是一个非常常见的需求,当然这对于zabbix来说肯定是支持的,需要使用zabbix的Discovery功能来实现,下面就给大家分享一下批量添加对口的占用。

 第一:自动扫描端口并监控报警

 1、编写脚本:check_port1.py

  1. #!/usr/bin/env python  
  2. #coding:utf-8  
  3.    
  4. import os, json  
  5.    
  6. port_list=[]  
  7. port_dict={"data":None}  
  8. cmd='''''netstat -tnlp|egrep -i "$1"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort |uniq   2>/dev/null'''  
  9. local_ports=os.popen(cmd).readlines()  
  10.    
  11. for port in local_ports:  
  12.     pdict={}  
  13.     pdict["{#TCP_PORT}"]=port.replace("\n", "")  
  14.     port_list.append(pdict)  
  15.    
  16. port_dict["data"]=port_list  
  17. jsonStr = json.dumps(port_dict, sort_keys=True, indent=4)  
  18.    
  19. print jsonStr  
  脚本的作用就是从被监控的服务器上面采集数据,并且转换为特定的字典格式,这种格式是zabbix可以识别的一种数据字典格式,使用python来编写相对shell来说更加便捷。

  将脚本放在 /etc/zabbix/scripts 路径下面

 2、修改被监控端的zabbix_agent.conf配置文件

  在配置文件中增加下面内容

UnsafeUserParameters=1 

UserParameter=tcpportlisten,/etc/zabbix/scripts/check_port1.py

 3、重启客户端服务

 4、测试

 执行命令:zabbix_get -s 192.168.92.9 -p 10050 -k tcpportlisten

  
 

  出现上面格式的数据,说明脚本编写成功

 友情提示:如果在执行上面命令的时候出现 zabbix_get :command not found 

  这说明您没有安装zabbix_get服务 

  执行 yum list all |grep zabbix 查看一下

    

 然后执行 yum install zabbix-get.x86_64 命令安装即可

 6、页面配置

  6.1添加模板  

   6.2 添加自动发现规则

   在上新创建的模板中点击 自动发现规则 然后选择  创建发现规则

 

 说明:上面的key 一定要和配置文件中的key 保持一致。就是我们在zabbix_agent.conf文件中添加的两行代码中的第二行中添加的参数key

  6.3创建监控项原型

 

  上面中的键值 中的 #TCP_PORT} 和我们的脚本 check_port1.sh 中的参数一致

  6.4 创建触发器类型

 

  注意这里的表态示count(#3,0,eq) > 1表示最近3次的返回值为0,这个条件触发一次则报警

  配置到这我们就完成了 zabbix自动扫描并监控的功能。

 第二、批量添加监听指定端口

  有时候我们不需要监控自动扫描出来的所有的端口,这些端口需要我们指定,这个需求也是比较常见的,有了上面的基础,实现这个东西其实是比较简单,其实仔细看看脚本就能实现。

  要实现这个功能我们只需要,将脚本替换成下面内容即可:

  1. #!/usr/bin/env python  
  2. #coding:utf-8  
  3. import os, json  
  4. portlist=["3306",  
  5.         "80",  
  6.         "22"]  
  7. port_list=[]  
  8. port_dict={"data":None}  
  9. #cmd='''netstat -tnlp|egrep -i "$1"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort |uniq   2>/dev/null'''  
  10. #local_ports=os.popen(cmd).readlines()  
  11. for port in portlist:  
  12.     pdict={}  
  13.     pdict["{#TCP_PORT}"]=port  
  14.         #pdict["{#TCP_PORT}"]=port.replace("\n", "")  
  15.     port_list.append(pdict)  
  16. port_dict["data"]=port_list  
  17. jsonStr = json.dumps(port_dict, sort_keys=Trueindent=4)  
  18. print jsonStr 
我们只需要在portlist 中添加我们想要监控的端口即可。

猜你喜欢

转载自blog.csdn.net/bbwangj/article/details/80666401