ris*_*tal
1
consensus
raft
考虑三个节点(A、B、C)获取键/值数据。并且发生了以下步骤
- 节点 A 接收键:值 (1:15)。它是一个领导者
- 它复制到节点 B 和节点 C
- 在预提交日志中对节点 B 进行的条目
- 节点 C 登录失败
- 来自节点 B 的 Ack 丢失。
- Nod A 输入失败并发送失败给客户端
- 节点 A 仍然是领导者,而 B 不在法定人数中
- 客户端从节点 A 读取键 1 并返回旧值。
- 节点 A 已关闭
- 节点 B 和节点 C 已启动
- 现在节点 B 在预提交日志中有一个条目,而节点 C 没有。
此时日志匹配如何发生。节点 B 是要提交该条目还是要丢弃它。如果它要提交,那么它会被读取不一致,或者如果它要丢弃,那么在其他情况下可能会丢失数据