zoukankan      html  css  js  c++  java
  • MongDB副本集自动转移故障

      当Primary节点连续10秒无法和其余节点通信时,从库将发生选举,在从库中选出一个库作为新的主库。第一个发起选举并且获得了大多数成员投票的Secondary节点,将成为主节点。

       MongoDB 3.2版本中新增了这样的一个功能:MongoDB引入了复制协议版本1(protocolVersion:1),以减少副本集故障转移时间并加速检测多个主节点的异常情况。默认情况下,新版本的副本集将使用protocolVersion1,老版本的副本集使用的是protocolVersion0。

      选举过程示意图如下所示:

      上图是通过在线的ProcessOn绘制的,其中背景色为红色的节点表示主节点于其它从节点失去通信了,此时从节点进行了选举活动;当选举成功后,绿色背景的节点就成为主节点了。

      故障切换过程通常会在一分钟内完成,副本集合的成员可能需要10到30秒才能声明Primary不可访问。从3.2版本开始,MongoDB加强了复制选举功能,减少了副本集故障转移的时间。

      在默认情况下,客户端从Primary读取数据,若是从Secondary读取数据的话,可能不是最新的,因为复制是异步的。使用“local”或“available” readConcern的客户端可以读取可能随后回滚的数据。  

      

  • 相关阅读:
    半主机模式和_MICROLIB 库
    工作中常用的git命令
    Mybatis延迟加载参数配置
    JUnit展示图形化测试结果
    可读、可维护、可扩展,原则、模式与重构
    乐观锁和悲观锁
    HashMap实现原理和底层数据结构?
    视图有啥用?
    单例模式常见有哪几种?
    RPC服务和HTTP服务的区别
  • 原文地址:https://www.cnblogs.com/bien94/p/12405416.html
Copyright © 2011-2022 走看看