【zabbix教程九】——zabbix3.0 批量添加端口監控

  引言

  我們在監控生產環境的服務的時候,通常需要對多個端口進行監控,如果我們手動的一個一個的添加,這回讓我們崩潰,所以批量添加端口監控是一個非常常見的需求,當然這對於zabbix來說肯定是支持的,需要使用zabbix的Discovery功能來實現,下面小編就給大家分享一下批量添加對口的佔用。

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

 1、編寫腳本:check_port1.sh


#!/usr/bin/env python
#coding:utf-8
 
import os, json
 
port_list=[]
port_dict={"data":None}
cmd='''netstat -tnlp|egrep -i "$1"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort |uniq   2>/dev/null'''
local_ports=os.popen(cmd).readlines()
 
for port in local_ports:
    pdict={}
    pdict["{#TCP_PORT}"]=port.replace("\n", "")
    port_list.append(pdict)
 
port_dict["data"]=port_list
jsonStr = json.dumps(port_dict, sort_keys=True, indent=4)
 
print jsonStr
  腳本的作用就是從被監控的服務器上面採集數據,並且轉換爲特定的字典格式,這種格式是zabbix可以識別的一種數據字典格式,使用python來編寫相對shell來說更加便捷。

  將腳本放在 /usr/lib/zabbix/alertscripts 路徑下面

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

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

UnsafeUserParameters=1
UserParameter=tcpportlisten,/usr/lib/zabbix/alertscripts/check_port1.sh

 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自動掃描並監控的功能。


 第二、批量添加監聽指定端口

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

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

#!/usr/bin/env python
#coding:utf-8
import os, json
portlist=["3306",
        "80",
        "22"]
port_list=[]
port_dict={"data":None}
#cmd='''netstat -tnlp|egrep -i "$1"|awk {'print $4'}|awk -F':' '{if ($NF~/^[0-9]*$/) print $NF}'|sort |uniq   2>/dev/null'''
#local_ports=os.popen(cmd).readlines()
for port in portlist:
	pdict={}
	pdict["{#TCP_PORT}"]=port
        #pdict["{#TCP_PORT}"]=port.replace("\n", "")
	port_list.append(pdict)
port_dict["data"]=port_list
jsonStr = json.dumps(port_dict, sort_keys=True, indent=4)
print jsonStr

我們只需要在portlist 中添加我們想要監控的端口即可。


 小結

 上面就是小編對批量添加端口的分享,希望能幫助您!

 


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章