raft理论与实践[5]-lab2c-持久化
admin
2023-02-16 02:20:05
0

准备工作

1、阅读raft论文
2、阅读raft理论与实践[1]-理论篇
3、阅读raft理论与实践[2]-lab2a
4、阅读raft理论与实践[3]-lab2a讲解
5、阅读raft理论与实践[4]-lab2b日志复制
6、查看我写的这篇文章: 模拟RPC远程过程调用

持久化

  • 如果基于Raft的服务器重新启动,则应从中断的位置恢复服务。 这就要求Raft保持持久状态,使其在重启后仍然有效。

  • 论文中Figure 2指出了那些字段需要持久化。

  • 并且raft.go包含有关如何保存和恢复持久性状态的示例。

  • 一个“真实的服务在每次Raft更改状态时将Raft的持久状态写入磁盘,并在重新启动时从磁盘读取最新的状态来恢复。

  • 但是我们的实现将会采用一个结构体的方式来模拟实现persister.go。

  • 调用Raft.Make()会提供一个Persister,它持有Raft的最近持久状态。

  • Raft应从该Persister初始化其状态,并在每次状态更改时修改其持久状态。

  • 主要使用Persister的ReadRaftState()和SaveRaftState()方法。

  • 在本实验中,我们需要完善在raft.go中的persist() and readPersist()方法。

  • 需要使用到labgob包中的编码与解码函数。

  • 你需要明确在什么时候需要持久化。

下面只列出两个重要实现,其他不再赘述,留给读者自己实现。

持久化编码

func (rf *Raft) persist() {
    // Your code here (2C).
    w := new(bytes.Buffer)

    e:= labgob.NewEncoder(w)
    e.Encode(rf.CurrentTerm)
    e.Encode(rf.VotedFor)
    e.Encode(rf.Logs)

    data := w.Bytes()
    rf.persister.SaveRaftState(data)
}

持久化解码

func (rf *Raft) readPersist(data []byte) {
    if data == nil || len(data) < 1 { // bootstrap without any state?
        return
    }
    // Your code here (2C).
    r := bytes.NewBuffer(data)

    d:= labgob.NewDecoder(r)
    d.Decode(&rf.CurrentTerm)
    d.Decode(&rf.VotedFor)
    d.Decode(&rf.Logs)
}

测试

> go test -v -run=2C

参考资料

github.com/dreamerjacks


相关内容

热门资讯

最新引进“新版九哥炸/金/花有... 最新引进“新版九哥炸/金/花有没有挂?”(原来真的有挂)您好,新版九哥炸/金/花这个游戏其实有挂的,...
玩家最新攻略“神皇牛牛是不是有... 有 亲,根据资深记者爆料神皇牛牛是可以开挂的,确实有挂(咨询软件无需打开...
重磅消息“樱花炸/金/花开挂神... 重磅消息“樱花炸/金/花开挂神器?”(太坑了原来有挂)您好,樱花炸/金/花这个游戏其实有挂的,确实是...
今日重磅消息“新永和牛牛可以开... 有 亲,根据资深记者爆料新永和牛牛是可以开挂的,确实有挂(咨询软件无需打...
【第一消息】“昆明文山麻将是不... 有 亲,根据资深记者爆料昆明文山麻将是可以开挂的,确实有挂(咨询软件无需...
【第一资讯】“毛豆炸/金/花到... 【第一资讯】“毛豆炸/金/花到底是不是挂?”(太坑了原来有挂)您好,毛豆炸/金/花这个游戏其实有挂的...
今日重大通报“昆明文山麻将有挂... 家人们!今天小编来为大家解答昆明文山麻将透视挂怎么安装这个问题咨询软件客服徽4282891的挂在哪里...
今日重磅消息“新道游炸/金/花... 您好:新道游炸/金/花这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在...
今日重大消息“欢乐斗地主掼蛋是... 有 亲,根据资深记者爆料欢乐斗地主掼蛋是可以开挂的,确实有挂(咨询软件无...
大学生收到外卖发现冰凉,申请退... 见习记者 刘世鹏 记者 任利近日,江苏一名大学生发布的一篇“后街墨鸭商家骂我早点死”的帖文引发网友关...