时间:2021-07-01 10:21:17 帮助过:18人阅读
2>、心跳:每个成员都需要知道其他成员的状态:那个是主节点?哪个可以作为同步源?哪个挂掉了?为了维护集合的最新视图,每个成员每个两秒就会向其他成员发送一个心跳请求(heartbeat request)。心跳请求的信息量非常小,用于检查每个成员的状态。成员状态:各个成员会通过心跳将自己的当前状态告诉其他成员。*STARTUP:成员刚启动时处于这个状态。在这个状态下,mongodb会尝试加载成员的副本集配置,配置加载成功之后,就进入STARTUP2状态。*STARTUP2:整个初始化同步过程都处于这个状态,但是如果是在普通成员上,这个状态只会持续几秒钟,在这个状态下,mongodb会创建几个线程,用于处理复制和选举,然后就会切换到RECOVERING状态。*RECOVERING:这个状态表明成员运转正常,但是暂时还不能处理读取请求。启动时,成员需要做一些检查以确保自己处于有效状态,之后才可以处理读取请求。再启动过程中,成为备份节点之前,每个成员都要经历RECOVERING状态。在处理非常耗时的操作时,成员也可能进入RECOVERING状态。当一个成员与其他成员脱节时,也会进入RECOVERING状态。*ARBITER:在正常的操作中,仲裁者应该始终处于ARBITER状态。*DOWN:如果一个正常运行的成员变得不可达,他就处于DOWN状态。如果有成员被报告为DOWN状态,它有可能仍然处于正常运行状态,不可达的原因可能是网络问题。*UNKNOWN:如果一个成员无法到达其他任何成员,其他成员就无法知道它处于什么状态,会将其报告为UNKNOWN状态。*REMOVED:当成员被移出副本集时,它就处于这个状态,如果被移出的成员又被重新添加到副本集中,它就会回到“正常”状态。*ROLLBACK:如果成员正在进行数据回滚,它就处于ROLLBACK状态。回滚过程结束时,服务器会转换为RECOVERING状态,然后成为备份节点。*FATAL:如果一个成员发生了不可挽回的错误,也不再尝试恢复正常的话,它就处于FATAL状态。
3>、选举:当一个成员无法到达主节点时,它就会申请被选举为主节点,希望被选举为主节点的成员,会向它能到达的所有成员发送通知。如果这个成员得到副本集中“大多数”赞成票,它就选举成功,会转换到主节点状态。如果达不到“大多数”的要求,那么选举失败,它仍然处于备份节点状态,之后还可以再次申请被选举为主节点。主节点会一直处于主节点状态,除非它由于不再满足“大多数”的要求或者挂了而退位,另外,副本集被重新配置也会导致主节点退位。如果主节点不可用,2秒钟(心跳的间隔是2秒)之内就会有成员发现这个问题,然后会立即开始选举,整个过程只会花费几毫秒。如果网络问题,或者是服务器过载导致响应缓慢,都可能触发选举,在这种情况下,心跳会在最多20秒之后超时,如果选举打成平局,每个成员都需要等待30秒才能开始下一次选举。
MongoDB副本集的组成
标签:不可用 操作日志 cin 初始化 最新 color 间隔 读取 应该