原文連結      https://www.cnblogs.com/JeremyWYL/archive/2018/01/22/8328081.html

引言

  在監控生產環境的服務的時候,通常需要對多個埠進行監控,如果我們手動一個一個的新增,這將是一件很麻煩的事情,為了減少這樣的情況,我們採用批量新增監控埠的方法,這是非常常見的需求,zabbix也是支援這種方式的,需要使用zabbix的Discovery功能來實現,下面小編就給大家分享一下批量新增埠的佔用。

  使用Zabbix監控如何監控伺服器埠狀態,大概的流程:zabbix監控服務自帶埠監控的監控項,所以需要我們自己手動定義所監控的item,客戶端獲取的埠列表通過agent傳送到服務端,

只需在服務端進行埠監控模板配置,然後自定義監控圖形,新增監控項即可!

下面就來給大家分享一下批量新增埠的方法!

第一:自動掃描埠並監控報警

1.編寫指令碼掃描埠

vim check_port.py

#!/usr/bin/env python

import os

import json

portlist = []

new_port_list = []

port_dict = {"data":None}

cmd = '''netstat -tnlp|egrep -i "$1"|awk {'print $4'}|'''

cmd += '''awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort -n| uniq 2>/dev/null'''

auto_localport = os.popen(cmd).readlines()

for ports in auto_localport:

new_port = ports.strip()

portlist.append(new_port)

for port in portlist:

pdict = {}

pdict["{#TCP_PORT}"] = port

new_port_list.append(pdict)

port_dict["data"] = new_port_list

jsonStr = json.dumps(port_dict,sort_keys=True,indent=4)

#python3

#print(jsonStr)

#python2

print jsonStr

指令碼的作用就是從被監控的伺服器上面採集資料,並且轉換為特定的字典格式,這種格式是zabbix可以識別的一種資料字典格式,使用python來編寫相對shell來說更加便捷。

將指令碼放在客戶端 /usr/lib/zabbix/alertscripts 路徑下面

2.修改被監控端的zabbix_agent.conf配置檔案

UnsafeUserParameters=1

UserParameter=tcpportlisten,/usr/lib/zabbix/alertscripts/check_port.sh

重啟客戶端服務

3.服務端測試

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

出現上面格式的資料,說明指令碼編寫成功!!!

第二:頁面配置

1.新增模板

2.新增自動發現規則

在上新建立的模板中點選-->自動發現規則-->然後選擇建立發現規則

說明:上面的key 一定要和配置檔案中的key 保持一致。就是我們在zabbix_agent.conf檔案中新增的兩行程式碼中的第二行中新增的引數key

3.建立監控項原型

上面中的鍵值 中的 #TCP_PORT} 和我們的指令碼 check_port.sh 中的引數一致

4.建立觸發器型別

 新增按鈕進入-->選擇原型

注意這裡的表態示count(#3,0,eq) > 1表示最近3次的返回值為0,這個條件觸發一次則報警.

配置到這我們就完成了,zabbix自動掃描並監控的功能.

第三:批量新增指定埠

有時候我們不需要監控自動掃描出來的所有的埠,這些埠需要我們指定,這個需求也是比較常見的,有了上面的基礎,實現這個東西其實是比較簡單,其實仔細看看指令碼就能實現。

要實現這個功能我們只需要,將指令碼替換成下面內容即可:

#!/usr/bin/env python

import json

port_list = ["80",

     "10050",

     "3306",

     "22",

     "8080"]

new_port = []

port_dict = {"data":None}

for port in port_list:

pdict = {}

pdict["{#TCP_PORT}"] = port

new_port.append(pdict)

port_dict["data"] = new_port

jsonStr = json.dumps(port_dict,sort_keys=True,indent=4)

#python3

#print(jsonStr)

#python2

print jsonStr

我們只需要在port_list中新增想要監控的埠號即可!注意格式,以逗號隔開!