如何使用zabbix监控mongod,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。
创新互联拥有网站维护技术和项目管理团队,建立的售前、实施和售后服务体系,为客户提供定制化的网站设计、成都网站制作、网站维护、电信机房托管解决方案。为客户网站安全和日常运维提供整体管家式外包优质服务。我们的网站维护服务覆盖集团企业、上市公司、外企网站、商城网站建设、政府网站等各类型客户群体,为全球成百上千家企业提供全方位网站维护、服务器维护解决方案。
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,mi***atio] 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]#当前等待获取写锁的队列
关于如何使用zabbix监控mongod问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。
当前名称:如何使用zabbix监控mongod
网页网址:http://cqwzjz.cn/article/ijpicp.html