首页 > 代码库 > zabbix监控mongod

zabbix监控mongod

参考 :http://john88wang.blog.51cto.com/2165294/1565968


http://aaronsa.blog.51cto.com/5157083/1741514  监控项讲解

1 被监控端写mongodb.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配置文件

添加如下内容

UserParameter=MongoDB.Status[*],/usr/local/zabbix/script/mongodb.sh $1 $2 $3


3 导入模板并重启zabbix_agentd服务

见附件


4 服务端测试 

/home/usr/local/zabbix/bin/zabbix_get -s ip -kMongoDB.Status[network,bytesIn]

40667759

#######################################################################################

mongodb 监控项
MongoDB.Status[opcounters,delete]
MongoDB.Status[opcounters,getmore]##自实例启动以来,在游标执行getMore次数
MongoDB.Status[opcounters,insert] ##自实例启动以来,执行insert次数
MongoDB.Status[opcounters,query] ##自实例启动以来,执行query次数
MongoDB.Status[opcounters,command]##自实例启动以来,执行其他操作的次数
MongoDB.Status[network,numRequests]
MongoDB.Status[mem,virtual]
MongoDB.Status[backgroundFlushing,average_ms]##平均每次刷新执行时间
MongoDB.Status[network,bytesOut]
MongoDB.Status[opcounters,update]
MongoDB.Status[opcountersRepl,command]
MongoDB.Status[process] ##当前实例是mongod,还是mongos
MongoDB.Status[uptime]##实例连续正常运行时间,单位秒
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]##当前实例堆大小,单位bytes
MongoDB.Status[extra_info,page_faults]##加载磁盘内容时发生页错误的次数
MongoDB.Status[mem,mapped]
MongoDB.Status[globalLock,activeClients,total] 当前活动的连接数
MongoDB.Status[cursors,totalOpen]
MongoDB.Status[cursors,timedOut]
MongoDB.Status[connections,available]##剩余多少可供连接
MongoDB.Status[connections,current] ##当前连接到本机处于活动状态的连接数
MongoDB.Status[connections,totalCreated]
MongoDB.Status[globalLock,activeClients,writers] 当前活动的写连接数
MongoDB.Status[globalLock,activeClients,readers] 当前活动的读连接数
MongoDB.Status[indexCounters,missRatio]
MongoDB.Status[globalLock,currentQueue,readers]  #当前等待获取读锁的队列
MongoDB.Status[mem,bits]
MongoDB.Status[indexCounters,misses] 访问索引时,索引不是在内存中被命中的次数
MongoDB.Status[indexCounters,resets] 索引计数器被重置的次数
MongoDB.Status[indexCounters,hits] 访问索引时,索引在内存中被命中的次数
MongoDB.Status[indexCounters,accesses]
MongoDB.Status[globalLock,currentQueue,total] #当前等待获取锁的队列
MongoDB.Status[globalLock,currentQueue,writers]#当前等待获取写锁的队列


本文出自 “渐行渐远” 博客,请务必保留此出处http://825536458.blog.51cto.com/4417836/1945854

zabbix监控mongod