raft理论与实践[5]-lab2c-持久化

发布时间:2020-03-22 11:39:48 作者:jonson_jackson
来源:网络 阅读:412

准备工作

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

持久化

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

持久化编码

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


推荐阅读:
  1. MySQL高可用工具Orchestrator怎么进行raft多节点模式安装
  2. 使用PHP与JavaScript怎么对请求进行判断

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

raft la

上一篇:PostgreSQL server端接收连接后fork进程

下一篇:提高数据中心能效必须与业务目标挂钩

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》