mongodb有db.serverstatus()命令,可以查看mongodb的运行状态,那么zabbix就可以调用这个命令实现mongodb的监控。
一、db.serverstatus()命令的使用
注:只有超级管理员账号才有权限使用此命令
1、查看mongodb服务状态
1
|
echo "db.serverstatus()" | mongo --port 37485 -u username -p 'password' --authenticationdatabase 'admin'
|
2、查看mongodb使用内存情况
1
|
echo "db.serverstatus().mem" | mongo --port 37485 -u username -p 'password' --authenticationdatabase 'admin'
|
3、查看mongodb连接数
1
|
echo "db.serverstatus().connections" | mongo --port 37485 -u username -p 'password' --authenticationdatabase 'admin'
|
二、创建监控配置文件
1、编写mongodb监控配置文件
1
2
3
4
5
|
vim /etc/zabbix/zabbix_agentd.d/mongodb.conf
userparameter=mongodb.status[*],/bin/echo "db.serverstatus().$1" |/data/mongodb/bin/mongo --port 37485 -u username -p 'password' --authenticationdatabase 'admin' | grep "$2" | awk -f ' : ' '{print $$2}' | awk -f ',' '{print $$1}'
userparameter=mongodb.ok,/bin/echo "db.serverstatus().ok" | /data/mongodb/bin/mongo --port 37485 -u username -p 'password' --authenticationdatabase 'admin' | sed -n '5p'
userparameter=mongodb.connections[*],/bin/echo "db.serverstatus().connections.$1" | /data/mongodb/bin/mongo
|
注:使用超级管理员账号
2、重启zabbix-agent
1
|
systemctl restart zabbix-agent
|
3、在zabbix server端测试
1
2
3
|
/data/zabbix/bin/zabbix_get -s xxx.xxx.xxx.xxx -p 10050 -k "mongodb.status[mem,virtual]"
/data/zabbix/bin/zabbix_get -s xxx.xxx.xxx.xxx -p 10050 -k "mongodb.connections[available]"
/data/zabbix/bin/zabbix_get -s xxx.xxx.xxx.xxx -p 10050 -k "mongodb.ok"
|
三、创建监控模板
1、添加监控模板
2、创建应用集
注:根据自己要监控的项创建应用集
3、创建监控项
注:请根据自己要监控的子项创建,将要监控的子项一一创建好
4、创建触发器
5、创建监控图形
四、主机添加监控模板
五、监控效果图
总结
以上所述是小编给大家介绍的zabbix3.4监控mongodb数据库状态的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对服务器之家网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!原文链接:https://blog.51cto.com/andyxu/2457182