Zabbix实战-简易教程--DB类--Mongo多实例
一、获取LLD监控类(多实例端口)
通过脚本获取MongoDB多实例,基本上和mysql一模一样:
#!/bin/bash #Fucation: mysql low-level discovery #Script_name: mysql_port_discovery.sh mongo() { port1=(`sudo /bin/netstat -tpln | awk -F "[ :]+" 'BEGIN {IGNORECASE=1; } /mongod/ && /127.0.0.1/ {print $5}'`) port2=(`sudo /bin/netstat -tpln | awk -F "[ : ]+" 'BEGIN {IGNORECASE=1; } /mongod/ && /0.0.0.0/ {print $5}'`) if [ ! -n "${port1}" ];then port=(`sudo /bin/netstat -tpln | awk -F "[ : ]+" 'BEGIN {IGNORECASE=1; } /mongod/ && /0.0.0.0/ {print $5}'`) else port=(`sudo /bin/netstat -tpln | awk -F "[ : ]+" 'BEGIN {IGNORECASE=1; } /mongod/ && /127.0.0.1/ {print $5}'`) fi max_index=$[${#port[@]}-1] printf '{\n' printf '\t"data":[' for key in `seq -s' ' 0 $max_index` do printf '\n\t\t{' printf "\"{#MONGOPORT}\":\"${port[${key}]}\"}" if [ $key -ne $max_index ];then printf "," fi done printf '\n\t]\n' printf '}\n' } $1
测试运行结果:
脚本已经上传至github地址:https://github.com/loveqx/zabbix-doc/blob/master/zabbix-scripts/zabbix-template-mongodb/monitor-mongo.sh
二、测试和自定义key
获取mongo多实例后,我们可以根据多实例端口和mongo admin进而获得各个监控项。
脚本如下:
#!/usr/bin/env python import commands import sys argv1=sys.argv[1] argv2=sys.argv[2] status = " /bin/echo 'db.serverStatus().%s' |/usr/local/mongodb/bin/mongo admin -uzabbix -psoft+5688 --port %s|grep -vE 'bye|admin|version'" %(sys.argv[2],sys.argv[1]) s,r=commands.getstatusoutput(status) if r.startswith('Number') or r.startswith('ISODate'): cmd = "echo '%s' |awk -F[,\(\)] '{print $2}'" %r s,r=commands.getstatusoutput(cmd) print r elif r.strip().isdigit(): print r else: print r
其中,zabbix为用户名,soft+5688为密码。
在Agent上自定义key:
#monitor mongoDB LLD UserParameter=custom.mongo.discovery[*], /bin/bash /etc/zabbix/externalscripts/monitor-mongo.sh $1 UserParameter=mongo_stats[*], python /etc/zabbix/externalscripts/monitor-mongdb.py $1 $2
其中:$1表示端口 $2表示item
比如:
三、制作模板
模板Template APP For Redis已经上传至github地址:https://github.com/loveqx/zabbix-doc/blob/master/zabbix-scripts/zabbix-template-mongodb/Template%20App%20For%20MongoDB.xml
部分监控项如下:
四、主机上套
五、效果图
1、获取item
2、全局锁相关
3、执行语句相关
4、网络流量
5、连接数
6、内存相关
六、脚本和参考文献
1、最后附上脚本和模板地址:
脚本:
2、获取item值脚本:https://github.com/loveqx/zabbix-doc/blob/master/zabbix-scripts/zabbix-template-mongodb/monitor-mongdb.py
2、参考文献