MongoDB报表实例 -- 隐藏成员方案

简介:

一个复制集的隐藏成员被配置为priority: 0,为了阻止它们被选举为主,设置hidden: true,阻止客户端连接到复制集路由读操作到它,即使他们指定了一个读偏好为secondary。


从一个隐藏成员读,你会看到一个独立的连接,而不是MongoReplicaSetClient类型,并指定slave_ok。


隐藏成员设置


你可以使用mongo shell来隐藏一个存在复制集的成员:

1
2
3
4
5
6
7
$ mongo admin -uxucy -p   
PRIMARY> conf = rs.config()    
  "_id"  "test" "version"  : 21,  "members"  : [ {  "_id"  : 0,  "host"  "xucy.local:27017" , }, {  "_id"  : 1,  "host"  "xucy.local:28017" , }, {  "_id"  : 2,  "host"  "xucy.local:29017" , } ] }    
PRIMARY> conf.members[1].priority = 0     
PRIMARY> conf.members[1].hidden =  true     
PRIMARY> conf.version += 1     
PRIMARY> rs.reconfig(conf)


xucy.local:28017现在隐藏。他将继续复制和像往常一样在选举中投票,但是连接到复制集的客户端将不会从它读取,即使xucy.local:29017下线:

1
2
3
4
5
6
irb(main):012:0> rs = Mongo::MongoReplicaSetClient.new([ "xucy.local:27017" "xucy.local:28017" "xucy.local:29017" ])    
=> <Mongo::MongoReplicaSetClient:0x3fe06e4fe564 @seeds=[[ "xucy.local" , 27017], [ "xucy.local" , 28017], [ "xucy.local" , 29017]] @connected= true >     
irb(main):013:0> rs.primary     
=> [ "xucy.local" , 27017]     
irb(main):014:0> rs.secondaries     
=>  #<Set: {}> # an empty set -- as far as this connection is concerned, there are no secondaries.


报表代码将会像这样(使用Ruby):

1
2
3
require  'mongo'    
reporting = Mongo::MongoClient. new ( "xucy.local" "28017" , slave_ok:  true # error checking goes here     
reporting[ 'my_application' ][ 'users' ].aggregate(...)


考虑


使用隐藏的成员是一个最简单的方式去配置实例用于专属的工作负载像报表,然而:


隐藏成员不能在紧急情况下读取


带有2个普通和1个隐藏成员在一个复制集中,对于写的错误容忍等价于一个常规的3个成员的集合。然而,你失去两个节点,你的生产应用将不能优雅的降级到只读模式,因为你的隐藏成员将不允许复制集客户端读取。如果你只是喜欢一个隐藏成员的简单,并且花费不是问题,使用一个5成员(带有一个成员隐藏)的集合代替。


对于复制集的包装代码不能被使用


很多团队创建应用定制的包装代码添加基础知识给客户端,由MongoDB驱动提供。因为你需要使用独立连接到你的报表实例,你不能重用投资,将会让你很伤心。














本文转自UltraSQL51CTO博客,原文链接: http://blog.51cto.com/ultrasql/1751796,如需转载请自行联系原作者






相关文章
|
人工智能 NoSQL atlas
4大企业实例解析:为何MongoDB Atlas成为AI服务构建的首选
本文所提及的仅是MongoDB Atlas在AI领域可实现功能的冰山一角
2135 1
|
NoSQL 容灾 MongoDB
MongoDB主备副本集方案:两台服务器使用非对称部署的方式实现高可用与容灾备份
在资源受限的情况下,为了实现MongoDB的高可用性,本文探讨了两种在两台服务器上部署MongoDB的方案。方案一是通过主备身份轮换,即一台服务器作为主节点,另一台同时部署备节点和仲裁节点;方案二是利用`priority`设置实现自动主备切换。两者相比,方案二自动化程度更高,适合追求快速故障恢复的场景,而方案一则提供了更多的手动控制选项。文章最后对比了这两种方案与标准三节点副本集的优缺点,指出三节点方案在高可用性和数据一致性方面表现更佳。
1322 5
|
存储 NoSQL MongoDB
【赵渝强老师】MongoDB复制集中的成员
MongoDB复制集通常由一个主库和两个从库组成,可选添加仲裁者。主库负责所有写操作并记录Oplog日志,从库异步同步主库的Oplog日志并应用操作。仲裁者不存储数据,主要用于保证复制集中成员数量为奇数,参与选举投票。视频讲解详见B站链接。
158 0
|
人工智能 NoSQL Go
Go MongoDB Driver 实例
Go MongoDB Driver 实例
141 1
|
存储 NoSQL MongoDB
使用mongodb数据库实例
【5月更文挑战第9天】MongoDB中的集合类似关系数据库的表,但不强制模式,允许嵌入式文档以实现更灵活的数据布局。安装MongoDB在Ubuntu上涉及添加源列表和更新,CentOS则需创建配置文件。MongoDB支持备份和恢复,以及全文搜索。其灵活模式和动态模式减少了开发中的复杂性,但并非无模式,大部分数据仍具结构化特点。
335 2
|
DataWorks NoSQL 关系型数据库
DataWorks操作报错合集之在使用 DataWorks 进行 MongoDB 同步时遇到了连通性测试失败,实例配置和 MongoDB 白名单配置均正确,且同 VPC 下 MySQL 可以成功连接并同步,但 MongoDB 却无法完成同样的操作如何解决
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
325 1
|
存储 监控 NoSQL
数据存储与分析:办公室电脑屏幕监控的MongoDB应用实例
在当今数字时代,数据的存储和分析变得愈发重要,尤其是在办公环境中,对电脑屏幕进行监控成为一种日益普遍的需求。本文将介绍如何利用MongoDB数据库实现办公室电脑屏幕监控,并通过代码实例展示其应用。
381 0
|
7月前
|
NoSQL MongoDB 数据库
数据库数据恢复—MongoDB数据库数据恢复案例
MongoDB数据库数据恢复环境: 一台操作系统为Windows Server的虚拟机上部署MongoDB数据库。 MongoDB数据库故障: 工作人员在MongoDB服务仍然开启的情况下将MongoDB数据库文件拷贝到其他分区,数据复制完成后将MongoDB数据库原先所在的分区进行了格式化操作。 结果发现拷贝过去的数据无法使用。管理员又将数据拷贝回原始分区,MongoDB服务仍然无法使用,报错“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
7月前
|
缓存 NoSQL Linux
在CentOS 7系统中彻底移除MongoDB数据库的步骤
以上步骤完成后,MongoDB应该会从您的CentOS 7系统中被彻底移除。在执行上述操作前,请确保已经备份好所有重要数据以防丢失。这些步骤操作需要一些基本的Linux系统管理知识,若您对某一步骤不是非常清楚,请先进行必要的学习或咨询专业人士。在执行系统级操作时,推荐在实施前创建系统快照或备份,以便在出现问题时能够恢复到原先的状态。
700 79

推荐镜像

更多