zoukankan      html  css  js  c++  java
  • Zabbix实现自动发现端口并监控

    转自天宇骑士博客随笔,表示感谢

    # vim discovertcpport.sh

    #!/bin/bash
    port_array=(`netstat -tnlp|egrep -i "$1"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort |uniq 2>/dev/null`)
    length=${#port_array[@]}
    printf "{ "
    printf ' '""data":["
    for ((i=0;i<$length;i++))
    do
    printf ' {'
    printf ""{#TCP_PORT}":"${port_array[$i]}"}"
    if [ $i -lt $[$length-1] ];then
    printf ','
    fi
    done
    printf " ] "
    printf "} "

    2、客户端增加discovery的key

    UserParameter=tcpportlisten[*],/usr/local/zabbix_agent/sbin/discovertcpport.sh "$1"

    我实验环境是zabbix 3.0 在tcpportlisten后面必须加上[*],否则会显示Item does not allow parameters

    3、重启zabbix_agentd服务

    # /etc/init.d/zabbix_agentd restart

    4 、服务端测试

    复制代码
    # /usr/local/zabbix/bin/zabbix_get  -s 192.168.0.111   -k tcpportlisten
    {
            "data":[
                    {"{#TCP_PORT}":"10050"},
                    {"{#TCP_PORT}":"22"},
                    {"{#TCP_PORT}":"80"}
            ]
    }
    复制代码

    返回类似以上内容即为正常

    5、在Linux模板中创建端口自动发现规则,点击配置-模板,在下面找到 Template OS Linux

    然后点开Template OS Linux,点击左上的自动发现规则

    再点击左上的创建自动发现规则

    按照以下来填

    点开刚刚创建好的自动发现规则

    然后创建监控原型

    此处要确实注意端口变量{#TCP_PORT}名称要与上面脚本中的保持一致。

    再创建触发器原型

    到此,监控端口已经完成。

    -------------------------------------------------------

    可能遇到的问题:

    1 、 执行脚本的时候发现提示  Not all processes could be identified, non-owned process info will not be shown, you would have to be root to see it all.) 应该是没权限的意思,

    2  、添加完自动发现规则之后,提示  Value should be a JSON object 这个错误

    解决办法是 vim /etc/sudoers

    #Defaults    requiretty  注释掉这个

    zabbix  ALL=(ALL)      NOPASSWD: ALL 添加此行

    然后在上面的脚本里面加上sudo netstat -tnlp|egrep -i "$1"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort|uniq

    还有个可能就是是否安装net-tools,也就是netstat命令,还有就是agentd.conf配置文件中是否设置allowroot=1,和UnsafeUserParameters=1,还有就是脚本是否有执行权限

    --------------------------------------------

    附:tomcat端口监控脚本

    复制代码
    #!/bin/bash
    sudo netstat -tnlp|grep "java"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort|uniq >/tmp/tomcat
    portarray=(`sudo grep "^$1$" /tmp/tomcat`)
    length=${#portarray[@]}
    printf "{
    "
    printf  '	'""data":["
    for ((i=0;i<$length;i++))
      do
         printf '
    		{'
         printf ""{#TOMCAT_PORT80}":"${portarray[$i]}"}"
         if [ $i -lt $[$length-1] ];then
                    printf ','
         fi
      done
    printf  "
    	]
    "
    printf "}
    "
    复制代码
  • 相关阅读:
    Bash : 冒泡排序
    Azure Load Balancer : 支持 IPv6
    Azure Load Balancer : 简介
    sudo 与输出重定向
    Linux lsof 命令
    Bash : IO 重定向
    LVM : 快照
    2014年全年总结
    使用Kindle4rss推送自己感兴趣的博文
    换SSD硬盘,重装系统,一阵子忙乱
  • 原文地址:https://www.cnblogs.com/hh2737/p/8257389.html
Copyright © 2011-2022 走看看