V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
duwan
V2EX  ›  问与答

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

  •  
  •   duwan · 2020-08-11 15:32:14 +08:00 · 1444 次点击
    这是一个创建于 1590 天前的主题,其中的信息可能已经有所发展或是发生改变。
    当重新连接一个节点时,当发“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}]

    大家帮忙看看我的这个流程哪里有问题啊?
    目前尚无回复
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5750 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 01:34 · PVG 09:34 · LAX 17:34 · JFK 20:34
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.