mongoDB nagios plugin (check_mongodb.py) BUG resolve

本文涉及的产品
云数据库 MongoDB,通用型 2核4GB
简介:
昨天一位同事问我现在我们的mongoDB在用什么做监控, 实在是惭愧, 一直没有对mongoDB进行比较细节的监控. 
仅仅是监控了服务器的一些性能指标.
今天赶紧看了一下mongoDB手册中关于监控的章节. 
下面是根据mongoDB官方推荐的几种监控方式之一, 结合我们正在使用的nagios进行的配置.
前提条件,
1. 需要nagios服务端
2. 在mongoDB所在的服务器需要安装nagios agent
3.  在mongoDB所在的服务器需要python >=2.4的版本 , 我这里使用的是2.4
4.  在mongoDB所在的服务器需要pymongo模块
   git clone git://github.com/mongodb/mongo-python-driver.git
    cd mongo-python-driver
    python setup.py install


为了简化安装步骤, 可以先在mongoDB服务器上安装git. 
有了以上前提就可以安装nagios-plugin-mongodb插件了.
转到nagios plugin目录例如/usr/local/nagios/libexec/
cd /usr/local/nagios/libexec/
git clone git://github.com/mzupan/nagios-plugin-mongodb.git

这就算安装好了.
cd nagios-plugin-mongodb
chmod 755 check_mongodb.py

使用语法如下 : 
./check_mongodb.py -h
usage: check_mongodb.py [options]

This Nagios plugin checks the health of mongodb.

options:
  -h, --help            show this help message and exit
  -H HOST, --host=HOST  The hostname you want to connect to
  -P PORT, --port=PORT  The port mongodb is runnung on
  -u USER, --user=USER  The username you want to login as
  -p PASSWD, --pass=PASSWD
                        The password you want to use for that user
  -W WARNING, --warning=WARNING
                        The warning threshold we want to set
  -C CRITICAL, --critical=CRITICAL
                        The critical threshold we want to set
  -A ACTION, --action=ACTION
                        The action you want to take
  -D, --perf-data       Enable output of Nagios performance data
  -d DATABASE, --database=DATABASE
                        Specify the database to check
  -s, --ssl             Connect using SSL

例如检查连接连接超时, 2秒警告, 4秒严重警告
check_mongodb.py -H 127.0.0.1 -P 2000 -A connect -W 2 -C 4
返回 : OK - Connection took 0 seconds

其他检测 : 
连接池已使用, 70%警告, 80%严重警告
check_mongodb.py -H 127.0.0.1 -P 2000 -A connections -W 70 -C 80
复制延时, 15秒警告, 30秒严重警告
check_mongodb.py -H 127.0.0.1 -P 2000 -A replication_lag -W 15 -C 30
内存使用, 18G警告, 22G严重警告(假设本机内存是24G)
check_mongodb.py -H 127.0.0.1 -P 2000 -A memory -W 18 -C 22
锁的耗时比例, 5%警告, 10%严重警告(锁占用时间长说明数据库已经超载)
check_mongodb.py -H 127.0.0.1 -P 2000 -A lock -W 5 -C 10
平均flush耗时, 100ms警告, 200ms严重警告(FLUSH时间长说明遇到IO写瓶颈, 或考虑升级硬盘, 或考虑shard)
check_mongodb.py -H 127.0.0.1 -P 2000 -A flushing -W 100 -C 200
最后一次flush的耗时, 100ms警告, 200ms严重警告(FLUSH时间长说明遇到IO写瓶颈, 或考虑升级硬盘, 或考虑shard)
check_mongodb.py -H 127.0.0.1 -P 2000 -A last_flush_time -W 100 -C 200
检测replicaset中所有节点的状态, 0, 0 (Depending which status it is it sends a waring during status 0, 3 and 5, critical if the status is 4, 6 or 8 and a ok with status 1, 2 and 7)
check_mongodb.py -H 127.0.0.1 -P 2000 -A replset_state -W 0 -C 0
检查索引的未命中率, .005警告, .01严重警告(值大的话考虑添加索引)
check_mongodb.py -H 127.0.0.1 -P 2000 -A index_miss_ratio -W .005 -C .01
检查数据库个数, 300警告, 500严重警告
check_mongodb.py -H 127.0.0.1 -P 2000 -A databases -W 300 -C 500
检查collection个数, 300警告, 500严重警告
check_mongodb.py -H 127.0.0.1 -P 2000 -A collections -W 300 -C 500
检查数据库大小, 300警告, 500严重警告(每个库一条, 主要用于框定该服务器可以承受的数据库大小后, 跟踪数据库的增长)
check_mongodb.py -H 127.0.0.1 -P 2000 -A database_size -W 4 -C 10 -d admin
check_mongodb.py -H 127.0.0.1 -P 2000 -A database_size -W 40 -C 45 -d local
check_mongodb.py -H 127.0.0.1 -P 2000 -A database_size -W 300 -C 400 -d digoal
注意, 如果检查了一个不存在的数据库, 这个数据库将被初始化, 占据空间, 所以需要慎用database_size的检测.

把这些条目加到/usr/local/nagios/etc/nrpe.cfg中
例如 :
command[check_mongodb_connections]=/usr/local/nagios/libexec/nagios-plugin-mongodb/check_mongodb.py -H 127.0.0.1 -P 2000 -A connections -W 70 -C 80
其他略.

重启xinetd服务
service xinetd restart

再到nagios服务端配置对应的条目.
略.

【BUG】
在使用过程中发现一些问题, 
使用以下代码进行跟踪
       import traceback
        print "*******\n%s********" %traceback.format_exc()

发现check_mongodb.py的第136行有点问题, 调用的pymongo.version不存在 : 
if pymongo.verison >= "2.1":

后来找到pymongo, 这个函数的名字应该是get_version_string, 所以需要修改以下check_mongodb.py
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。   相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
2天前
|
存储 NoSQL MongoDB
MongoDB如何创建数据库
MongoDB如何创建数据库
|
2天前
|
存储 NoSQL MongoDB
MongoDB数据库转换为表格文件的Python实现
MongoDB数据库转换为表格文件的Python实现
24 0
|
2天前
|
存储 NoSQL 关系型数据库
Percona XtraBackup是否支持MongoDB数据库备份?
【5月更文挑战第13天】Percona XtraBackup是否支持MongoDB数据库备份?
27 1
|
2天前
|
NoSQL atlas MongoDB
Nosql数据库MongoDB的使用场景
【5月更文挑战第5天】 MongoDB是全球性的多云数据库,可在私有、公共和混合云中运行,提供高可用性、扩展性和合规性。 安全特性包括认证、授权、审计、网络隔离和加密。可提供跨云操作、可视化工具、搜索功能和数据湖支持,适用于现代应用开发,包括边缘数据处理。
28 1
|
2天前
|
JSON NoSQL MongoDB
理解Nosql数据库的mongodb
【5月更文挑战第5天】MongoDB是2009年发布的一款通用型NoSQL数据库,结合了关系模型和NoSQL的优点,适用于各种现代应用。其特点包括图形界面、数据服务、云基础设施集成(AWS, Azure, Google Cloud)。它具备全面的查询能力、ACID事务、可调整的一致性保证,并有多语言驱动及工具,可在任何地方运行。
23 4
|
2天前
|
存储 NoSQL 关系型数据库
【MongoDB 专栏】MongoDB 与传统关系型数据库的比较
【5月更文挑战第10天】本文对比了MongoDB与传统关系型数据库在数据模型、存储结构、扩展性、性能、事务支持、数据一致性和适用场景等方面的差异。MongoDB以其灵活的文档模型、优秀的扩展性和高性能在处理非结构化数据和高并发场景中脱颖而出,而关系型数据库则在事务处理和强一致性上更具优势。两者各有适用场景,选择应根据实际需求来定。随着技术发展,两者正相互融合,共同构建更丰富的数据库生态。
【MongoDB 专栏】MongoDB 与传统关系型数据库的比较
|
2天前
|
存储 NoSQL 关系型数据库
MongoDB非关系型数据库实战
【5月更文挑战第6天】MongoDB,流行的NoSQL数据库,以其灵活的数据模型和高性能备受青睐。本文介绍了MongoDB的基础,包括文档型数据库特性、安装配置、数据操作。通过电商订单管理的实战案例,展示了MongoDB在处理复杂数据结构和大规模数据时的优势,适用于电商、游戏、视频直播等场景。MongoDB的索引、全文搜索和地理空间功能进一步增强了其实用性。注意性能优化和扩展性以确保系统稳定性和可靠性。
|
2天前
|
弹性计算 NoSQL Shell
一键安装 MongoDB 数据库脚本
【4月更文挑战第29天】
19 4