首页 Linux网维 Zabbix监控(十二):自动监控Linux端口

Zabbix监控(十二):自动监控Linux端口

参考官方文档:https://www.zabbix.com/documentation/2.0/manual/discovery/low_level_discovery1、客户端新…

参考官方文档:https://www.zabbix.com/documentation/2.0/manual/discovery/low_level_discovery1、客户端新建脚本12345678

9101112131415161718[root@agent01 ~]# vi /usr/local/zabbix_agent/sbin/discovertcpport.sh#!/bin/bashportarray=(`netstat -tnlp|egrep -i “$1″|awk {print $4}|awk -F: {if ($NF~/^[0-9]*$/) print $NF}|sort|uniq`)

#namearray=(`netstat -tnlp|egrep -i “$1″|awk {print $7}|awk -F/ {if ($NF != “Address”) print $NF}|uniq`)

length=${#portarray[@]}printf “{\n”printf  \t”\”data\”:[“for ((i=0;i<$length;i++))  do     printf \n\t\t{

printf “\”{#TCP_PORT}\”:\”${portarray[$i]}\”}”#     printf “\”{#TCP_NAME}\”:\”${namearray[$i]}\”}”

if [ $i -lt $[$length-1] ];then                printf ,     fi  doneprintf  “\n\t]\n”printf “}\n”

脚本说明:使用netstat命令输出端口号;-tnlp=Tcp协议+不显示别名+listen状态+显示程序名称;$1~$9表示输出的第几个参数;awk {print $4}表示输出第4个参数(如0.0.0.0:80);awk -F: {if ($NF~/^[0-9]*$/) print $NF}表示截取冒号后面的值,且只能是0~9的数字;|sort|uniq表示排序和去重。

脚本中注释掉的两行是用来监控服务的,只需替换掉其上的一行就是个扫描服务的脚本了2、客户端增加discovery的key12[root@agent01 ~]# echo “UnsafeUserParameters=1” >> /usr/local/zabbix_agent/etc/zabbix_agentd.conf。

[root@agent01 ~]# echo “UserParameter=tcpportlisten,/usr/local/zabbix_agent/sbin/discovertcpport.sh \”\$1\””>>/usr/local/zabbix_agent/etc/zabbix_agentd.conf

提示:客户端的脚本和配置可在安装时就提前做好,参考我的安装文档:http://ywzhou.blog.51cto.com/2785388/15790603、重启zabbix_agentd服务1234[root@agent01 ~]# service zabbix_agentd restart

#实际上我发现restart命令无效,因此使用下面的方法Kill进程[root@agent01 ~]# ps ax|grep zabbix_agentd|grep -v grep |awk {print $1}|xargs kill -9

[root@agent01 ~]# /etc/init.d/zabbix_agentd start4、测试客户端运行脚本测试:123[root@agent01 ~]# cd /usr/local/zabbix_agent/sbin

[root@agent01 sbin]# chmod +x discovertcpport.sh[root@agent01 sbin]# ./discovertcpport.sh

Zabbix监控(十二):自动监控Linux端口插图

客户端测试扫描端口命令:1[root@agent01 ~]# netstat -tnlp|egrep -i “$1″|awk {print $4}|awk -F: {if ($NF~/^[0-9]*$/) print $NF}

Zabbix监控(十二):自动监控Linux端口插图1

客户端测试扫描服务命令:1[root@agent01 ~]# netstat -tnlp|egrep -i “$1″|awk {print $7}|awk -F/ {print $NF}

Zabbix监控(十二):自动监控Linux端口插图2

可以看到上面两条命令输出都有重复项,因为没有加上去重|uniq以下命令在客户端执行,目录是zabbix_agent,和服务端不一样,命令没有添加到init.d中,因此必须输入全路径,否则提示命令无效1[root@zabbix ~]# /usr/local/zabbix_agent/bin/zabbix_get -s 127.0.0.1 -k tcpportlisten

注意:很可能的情况是客户端执行该命令无反应,不理会,直接往下走,能在zabbix上监控到就行。下图是在zabbix服务器创建的脚本,然后进行本地的zabbix_get测试:

Zabbix监控(十二):自动监控Linux端口插图3

 5、在Linux模板中创建端口自动发现规则

Zabbix监控(十二):自动监控Linux端口插图4

设置自动发现规则名称和KEY:

Zabbix监控(十二):自动监控Linux端口插图5

创建Item原型:

Zabbix监控(十二):自动监控Linux端口插图6

创建触发器原型:

Zabbix监控(十二):自动监控Linux端口插图7

创建图像原型(可以忽略):

Zabbix监控(十二):自动监控Linux端口插图8

6、查看自动发现结果

Zabbix监控(十二):自动监控Linux端口插图9

查看最近值:1表示端口正在监听状态

Zabbix监控(十二):自动监控Linux端口插图10

查看自动发现图像:

Zabbix监控(十二):自动监控Linux端口插图11

结论:自动发现可以很好的监控服务器端口,当有新端口开启时会自己扫描到,不用人为的去关心,建议将不重要的触发器禁用,否则会频繁收到报警通知,有的端口是一会上一会下的关于自动监控服务,读者可以自已去尝试,命令已经写在上面了,应该不是问题吧。

免责声明:文章内容不代表本站立场,本站不对其内容的真实性、完整性、准确性给予任何担保、暗示和承诺,仅供读者参考,文章版权归原作者所有。如本文内容影响到您的合法权益(内容、图片等),请及时联系本站,我们会及时删除处理。

作者: 3182235786a

为您推荐

linux文件命令

linux文件命令

在 Linux 中,我们可以使用 `with open()` 语句和 `write()` 函数来写入文件。以下是一个简单...
linux的命令

linux的命令

以下是一个简单的 Linux 命令示例,该命令将显示当前日期和时间: “`c #include <st...
linux 命令

linux 命令

由于 Linux 命令是由 C 语言编写的,因此下面是一个简单的用中文编写的 Linux 命令示例,它将输出“Hello...
linux命令tar

linux命令tar

这个问题看起来有些模糊,我不确定您是想了解如何在 Linux 系统中使用 tar 命令,还是如何编写一个名为 tar 的...
linux压缩命令

linux压缩命令

Linux压缩命令:高效管理文件和目录 Linux操作系统提供了一系列强大的压缩命令,使您能够高效地管理文件和目录。无论...

发表回复

返回顶部