mongodb副本集搭建和使用

副本集是mongodb提供的一种高可用解决方案。副本集能自动感知主节点的下线,并提升其中一个从节点作为主节点。

副本集架构图

mongodb副本集中的角色

1. Primary

   默认情况下,读写都是在Primary上操作的。

2. Secondary

   通过oplog来重放Primary上的所有操作,拥有Primary节点数据的完整拷贝。

   默认情况下,不可写,也不可读。

   根据不同的需求,Secondary又可配置为如下形式:

  •    Priority 0 Replica Set Members

        优先级为0的节点,优先级为0的成员永远不会被选举为primary。

        在mongoDB副本集中,允许给不同的节点设置不同的优先级。

        优先级的取值范围为0-1000,可设置为浮点数,默认为1。

        拥有最高优先级的成员会优先选举为primary。

        譬如,在副本集中添加了一个优先级为2的成员node3:27020,而其它成员的优先级为1,只要node3:27020拥有最新的数据,那么当前的primary就会自动降

        级,node3:27020将会被选举为新的primary节点,但如果node3:27020中的数据不够新,则当前primary节点保持不变,直到node3:27020的数据更新到最新。

  •     Hidden Replica Set Members-隐藏节点

         隐藏节点的优先级同样为0,同时对客户端不可见

         使用rs.status()和rs.config()可以看到隐藏节点,但是对于db.isMaster()不可见。客户端连接到副本集时,会调用db.isMaster()命令来查看可用成员信息。

         所以,隐藏节点不会受到客户端的读请求。

         隐藏节点常用于执行特定的任务,譬如报表,备份。

  •      Delayed Replica Set Members-延迟节点

         延迟节点会比primary节点延迟指定的时间(通过slaveDelay参数来指定)

         延迟节点必须是隐藏节点。

副本集中数据同步过程Primary节点写入数据,Secondary通过读取Primary的oplog得到复制信息,开始复制数据并且将复制信息写入到自己的oplog

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值