【Mit6.824】实验-Lab2C-Raft 持久化

实验-Lab2C-Raft 持久化

任务

通过添加保存和恢复持久状态的代码,完成raft.go中的persist()readPersist() 函数,需要将状态编码(或“序列化”)为字节数组,以便将其传递给Persister。使用labgob编码器。根据Raft论文,我们只需要持久化 currentTerm, votedFor 和 logs 三个数据。

persist():将状态持久化到磁盘中
readPersist():当节点重启时,会重新读取状态恢复

在更改 currentTerm, votedFor 和 logs 的地方我们都需要调用persist()方法进行持久化

代码

func (rf *Raft) persist() {
	rf.persister.SaveRaftState(rf.encodeState())
}

func (rf *Raft) readPersist(data []byte) {
	if data == nil || len(data) == 0 {
		return
	}
	r := bytes.NewBuffer(data)
	d := labgob.NewDecoder(r)
	var currentTerm, votedFor int
	var logs []Entry
	if d.Decode(&currentTerm) != nil ||
		d.Decode(&votedFor) != nil ||
		d.Decode(&logs) != nil {
	}
	rf.currentTerm, rf.votedFor, rf.logs = currentTerm, votedFor, logs
	//刚刚读取完持久化信息,日志还没被执行
	rf.lastApplied, rf.commitIndex = rf.logs[0].Index, rf.logs[0].Index
}

//将状态序列化为字节数组
//只需要持久化 currentTerm, votedFor, logs
func (rf *Raft) encodeState() []byte {
	w := new(bytes.Buffer)
	e := labgob.NewEncoder(w)
	e.Encode(rf.currentTerm)
	e.Encode(rf.votedFor)
	e.Encode(rf.logs)
	return w.Bytes()
}
  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值