求教 6.824 lab2B TestFailAgree2B 怎么过啊?要被搞蒙了。。

2020-08-11 15:32:14 +08:00
 duwan
当重新连接一个节点时,当发“106”命令时 总是报:apply error: server 0 apply out of order 7

当发完 106 命令时我的日志如下:[{1 101} {1 102} {1 103} {1 104} {1 105} {1 106} {8 106}]

我的程序流程应该是这样的:

1. 重连节点(例如为节点 3 )
2. Leader (节点 1 )收到命令“106”,存入日志并成功 commited (因为节点 2 也成功),但是由于 Term 为 1 直接被刚刚重连的节点 3 拒绝(节点 3 由于网络故障一直触发选、举且不成功,节点 3 此时当前 Term 为 7 )
3. Leader 收到节点 3 的拒绝,发现节点 3 的 term 比它大。重新触发选、举,并当选。Term 为 8
4. test 程序又重试,重新发送命令“106”
5. 所以日志会有两条"106"命令[{1 101} {1 102} {1 103} {1 104} {1 105} {1 106} {8 106}]

大家帮忙看看我的这个流程哪里有问题啊?
1440 次点击
所在节点    问与答
0 条回复

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/697387

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX