转自天宇骑士博客随笔,表示感谢
# vim discovertcpport.sh
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 注释掉这个
然后在上面的脚本里面加上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 "} "