如何使用zabbix監(jiān)控mongod,針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。
創(chuàng)新互聯(lián)擁有網(wǎng)站維護(hù)技術(shù)和項(xiàng)目管理團(tuán)隊(duì),建立的售前、實(shí)施和售后服務(wù)體系,為客戶提供定制化的網(wǎng)站設(shè)計(jì)、成都網(wǎng)站制作、網(wǎng)站維護(hù)、電信機(jī)房托管解決方案。為客戶網(wǎng)站安全和日常運(yùn)維提供整體管家式外包優(yōu)質(zhì)服務(wù)。我們的網(wǎng)站維護(hù)服務(wù)覆蓋集團(tuán)企業(yè)、上市公司、外企網(wǎng)站、商城網(wǎng)站建設(shè)、政府網(wǎng)站等各類型客戶群體,為全球成百上千家企業(yè)提供全方位網(wǎng)站維護(hù)、服務(wù)器維護(hù)解決方案。
1 被監(jiān)控端寫(xiě)MongoDB.sh
注意:里面的路徑和你的端口要看自己的實(shí)際情況
case $# in 1) output=$(/bin/echo "db.serverStatus().$1" |/usr/local/mongodb/bin/mongo admin --port 27017|sed -n '3p') ;; 2) output=$(/bin/echo "db.serverStatus().$1.$2" |/usr/local/mongodb/bin/mongo admin --port 27017|sed -n '3p') ;; 3) output=$(/bin/echo "db.serverStatus().$1.$2.$3" |/usr/local/mongodb/bin/mongo admin --port 27017|sed -n '3p') ;; esac #check if the output contains "NumberLong" if [[ "$output" =~ "NumberLong" ]];then echo $output|sed -n 's/NumberLong(//p'|sed -n 's/)//p' else echo $output fi
2 編輯zabbix_agentd.conf配置文件
添加如下內(nèi)容
UserParameter=MongoDB.Status[*],/usr/local/zabbix/script/mongodb.sh $1 $2 $3
3 導(dǎo)入模板并重啟zabbix_agentd服務(wù)
見(jiàn)附件
4 服務(wù)端測(cè)試
/home/usr/local/zabbix/bin/zabbix_get -s ip -kMongoDB.Status[network,bytesIn]
40667759
#######################################################################################
mongodb 監(jiān)控項(xiàng) MongoDB.Status[opcounters,delete] MongoDB.Status[opcounters,getmore]##自實(shí)例啟動(dòng)以來(lái),在游標(biāo)執(zhí)行g(shù)etMore次數(shù) MongoDB.Status[opcounters,insert] ##自實(shí)例啟動(dòng)以來(lái),執(zhí)行insert次數(shù) MongoDB.Status[opcounters,query] ##自實(shí)例啟動(dòng)以來(lái),執(zhí)行query次數(shù) MongoDB.Status[opcounters,command]##自實(shí)例啟動(dòng)以來(lái),執(zhí)行其他操作的次數(shù) MongoDB.Status[network,numRequests] MongoDB.Status[mem,virtual] MongoDB.Status[backgroundFlushing,average_ms]##平均每次刷新執(zhí)行時(shí)間 MongoDB.Status[network,bytesOut] MongoDB.Status[opcounters,update] MongoDB.Status[opcountersRepl,command] MongoDB.Status[process] ##當(dāng)前實(shí)例是mongod,還是mongos MongoDB.Status[uptime]##實(shí)例連續(xù)正常運(yùn)行時(shí)間,單位秒 used_connections_percentage used_memory_percentage MongoDB.Status[opcountersRepl,update] MongoDB.Status[opcountersRepl,query] MongoDB.Status[opcountersRepl,delete] MongoDB.Status[opcountersRepl,getmore] MongoDB.Status[opcountersRepl,insert] MongoDB.Status[mem,resident] MongoDB.Status[network,bytesIn] MongoDB.Status[extra_info,heap_usage_bytes]##當(dāng)前實(shí)例堆大小,單位bytes MongoDB.Status[extra_info,page_faults]##加載磁盤(pán)內(nèi)容時(shí)發(fā)生頁(yè)錯(cuò)誤的次數(shù) MongoDB.Status[mem,mapped] MongoDB.Status[globalLock,activeClients,total] 當(dāng)前活動(dòng)的連接數(shù) MongoDB.Status[cursors,totalOpen] MongoDB.Status[cursors,timedOut] MongoDB.Status[connections,available]##剩余多少可供連接 MongoDB.Status[connections,current] ##當(dāng)前連接到本機(jī)處于活動(dòng)狀態(tài)的連接數(shù) MongoDB.Status[connections,totalCreated] MongoDB.Status[globalLock,activeClients,writers] 當(dāng)前活動(dòng)的寫(xiě)連接數(shù) MongoDB.Status[globalLock,activeClients,readers] 當(dāng)前活動(dòng)的讀連接數(shù) MongoDB.Status[indexCounters,mi***atio] MongoDB.Status[globalLock,currentQueue,readers] #當(dāng)前等待獲取讀鎖的隊(duì)列 MongoDB.Status[mem,bits] MongoDB.Status[indexCounters,misses] 訪問(wèn)索引時(shí),索引不是在內(nèi)存中被命中的次數(shù) MongoDB.Status[indexCounters,resets] 索引計(jì)數(shù)器被重置的次數(shù) MongoDB.Status[indexCounters,hits] 訪問(wèn)索引時(shí),索引在內(nèi)存中被命中的次數(shù) MongoDB.Status[indexCounters,accesses] MongoDB.Status[globalLock,currentQueue,total] #當(dāng)前等待獲取鎖的隊(duì)列 MongoDB.Status[globalLock,currentQueue,writers]#當(dāng)前等待獲取寫(xiě)鎖的隊(duì)列
關(guān)于如何使用zabbix監(jiān)控mongod問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。