溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫

發(fā)布時間:2021-10-25 15:05:00 來源:億速云 閱讀:126 作者:小新 欄目:系統(tǒng)運維

這篇文章主要為大家展示了“怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫”這篇文章吧。

監(jiān)控mongo寫個模板其實挺快的,如果公司每個mongo使用的端口都一致的話,就可直接建立一套模板,然后這個模板鏈接到各個服務(wù)器上即可。但如果公司使用mongo的端口如果不一致的話,那建議使用zabbix的自動發(fā)現(xiàn)的功能,自動發(fā)現(xiàn)mongo監(jiān)聽的端口,并對它進行相關(guān)數(shù)據(jù)的收集。

先看一下效果圖

怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫

此監(jiān)控圖是zabbix的篩選功能可能把相關(guān)的圖整合到一個頁面里面去。

具體的自動發(fā)現(xiàn)實現(xiàn)如下:

怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫

探索規(guī)則配置如上,機器上的zabbix agent配置如下:

UserParameter=mongo.discover,python /usr/local/zabbix/discover_mongo.py

其中/usr/local/zabbix/discover_mongo.py為自動發(fā)現(xiàn)的腳本,腳本內(nèi)容如下:

#coding:utf-8 import simplejson as json import commands  (status, output) = commands.getstatusoutput('''sudo netstat -tlnp|grep 'mongod'|awk '{print $4}'|awk -F':' '{print $(NF)}'|sort -u|grep -v "^28"''') outputs = output.split('\n') ports = [] for port in  outputs:     ports += [{'{#MONGOPORT}': port}]  print json.dumps({'data':ports},sort_keys=True,indent=4)

使用系統(tǒng)命令netstat把監(jiān)聽的端口篩選出來,然后以json的格式進行輸出。定義到此就可以自動發(fā)現(xiàn)zabbix監(jiān)聽的端口。

注意:netstat一般zabbix用戶沒有權(quán)限,需要visudo進行對應(yīng)的設(shè)置,此腳本可能得針對自己的環(huán)境進行相對的調(diào)整。

探索完端口后,zabbix server就需要以端口為其中一個參數(shù)向zabbix agent取數(shù)據(jù),其中項目原型配置如下:

怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫

如果返回的{#MONGOPORT}有多個的話,那監(jiān)控項目就乘以幾。

其中mongo.status的定義如下(此定義還是zabbix agent下):

UserParameter=mongo.status[*],sh /usr/local/zabbix/check_mongo.sh -p $1 -k $2  -K $3

使用一個腳本傳入?yún)?shù)來獲取mongo的一些數(shù)據(jù)收集,后續(xù)可直接擴展此腳本(-p代表端口),mongo的serverStatus有多個參數(shù),采集的就用到opcounters等,-k和-K能具體獲取其數(shù)值。其中腳本如下:

#!/bin/sh while getopts "p:k:K:" opt do         case $opt in                 p ) mongo_port=$OPTARG;;                 k ) key1=$OPTARG;;                 K ) key2=$OPTARG;;                 ? )                 echo 'parameter is wrong!'                 exit 1;;         esac done  if [ ! "${mongo_port}" ] || [ ! "${key1}" ] || [ ! "${key2}" ];then         echo "parameter is null"                 exit 1 fi  echo "db.serverStatus().${key1}"|mongo --port=${mongo_port}|sed 's/,/\r\n/g'|grep "${key2}" |awk -F':|,|}' '{print $2}'

部署完一個模板,把模板關(guān)聯(lián)到mongo的機器,就能收集相關(guān)的操作信息。在模板上再添加一個圖形原型,如下:

怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫

模板應(yīng)用完如果沒問題就可以在zabbix的篩選中把mongo集群的數(shù)據(jù)匯在一個網(wǎng)頁上進行查看。

以上是“怎么使用Zabbix的自動發(fā)現(xiàn)來監(jiān)控mongo數(shù)據(jù)庫”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI