MongoDB报表实例 -- 隐藏成员方案
admin
2023-02-06 12:20:04
0

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


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


隐藏成员设置


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

$ 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下线:

irb(main):012:0> rs = Mongo::MongoReplicaSetClient.new(["xucy.local:27017", "xucy.local:28017", "xucy.local:29017"])    
=>      
irb(main):013:0> rs.primary     
=> ["xucy.local", 27017]     
irb(main):014:0> rs.secondaries     
=> # # an empty set -- as far as this connection is concerned, there are no secondaries.


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

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驱动提供。因为你需要使用独立连接到你的报表实例,你不能重用投资,将会让你很伤心。


相关内容

热门资讯

告别校外供餐,2027年底所有... 今天(1月14日),北京市教育委员会召开北京市中小学校园餐专项整治工作推进现场会。记者从会上了解到,...
瑞达期货:瑞达瑞控科技完成AP... 证券之星消息,瑞达期货(002961)01月13日在投资者关系平台上答复投资者关心的问题。 投资者:...
未野、GXA、小米专业级筋膜枪... 对于当下年轻人而言,一把靠谱的专业级筋膜枪可是精准破解放松需求的日常护理刚需。真正的优质专业级筋膜枪...
2男1女专盗寺庙功德箱,警方:... 1月14日,据辽宁葫芦岛公安消息:近日,市局南票分局成功打掉一个流窜多省专门盗窃寺庙功德箱的犯罪团伙...
这台机器狗售价不到1万!卖了近... 本文自南都·湾财社。 采写 | 南都·湾财社记者 胡雯雯 编辑 | 柴华 在刚过去的拉斯维加斯CES...
雷宁普电气取得探测器碰撞设备专... 国家知识产权局信息显示,广东雷宁普电气检测技术有限公司取得一项名为“一种探测器碰撞设备”的专利,授权...
伊朗军方:近期系列恐袭是敌方精... △穆萨维(资料图)当地时间14日,伊朗武装部队总参谋长穆萨维在一则声明中称,恐怖分子的行动是以色列去...
向“新”而行的二次增长——解码... 实验室里的“较真”:“瞪羚”这样炼成 1月9日,湖北民本集团实验室为了攻克高比表氢氧化钙技术难题,岳...
新型人工智能模型可通过睡眠数据... 新华社华盛顿1月13日电 许多疾病在身体出现明显症状之前会在睡眠状况中有所体现。美国科研人员日前开发...
车厘子为什么用J表示大小? 又到了买车厘子的季节,除了红彤彤的车厘子,目光还容易被包装标签上那个神秘的字母吸引——“J”,比如“...