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