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

2020-02-11  本文已影响0人  唯识相链2

准备工作

持久化

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

持久化编码

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

参考资料

上一篇 下一篇

猜你喜欢

热点阅读