网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

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

一个复制集的隐藏成员被配置为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驱动提供。因为你需要使用独立连接到你的报表实例,你不能重用投资,将会让你很伤心。


当前题目:MongoDB报表实例--隐藏成员方案
文章地址:http://bjjierui.cn/article/gechoi.html

其他资讯