mit 6.824 lab2 C,raft持久化(lab2D中有关于此处大量代码修改找出了很多错误)

lab2 C 实现的就是持久化非常简单,在mit提供的框架中,持久化是存储在内存中。

首先看论文

mit 6.824 lab2 C,raft持久化(lab2D中有关于此处大量代码修改找出了很多错误)

需要持久化的元素。

根据lab2C的描述中我们可以知道需要实现的函数:

persist 持久化

readPersist 读取持久化数据

实现方式也给了例子非常简单:

func (rf *Raft) persist() {   // Your code here (2C).   // Example:   // w := new(bytes.Buffer)   // e := labgob.NewEncoder(w)   // e.Encode(rf.xxx)   // e.Encode(rf.yyy)   // data := w.Bytes()   // rf.persister.SaveRaftState(data)

}

就是用mit提供的序列化包。

func (rf *Raft) readPersist(data []byte) {   if data == nil || len(data) < 1 { // bootstrap without any state?      return   }   // Your code here (2C).   // Example:   // r := bytes.NewBuffer(data)   // d := labgob.NewDecoder(r)   // var xxx   // var yyy   // if d.Decode(&xxx) != nil ||   //    d.Decode(&yyy) != nil {   //   error...   // } else {   //   rf.xxx = xxx   //   rf.yyy = yyy   // }简单易懂。最关键的点是在哪些位置需要序列化。所有导致使所需序列化元素发生改变的位置都要进行序列化。持久化位置:  start 位置  投票  开启新的term

mit 6.824 lab2 C,raft持久化(lab2D中有关于此处大量代码修改找出了很多错误)

Original: https://www.cnblogs.com/thotf/p/16693680.html
Author: thotf
Title: mit 6.824 lab2 C,raft持久化(lab2D中有关于此处大量代码修改找出了很多错误)

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/582246/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • VMware 虚拟机图文安装和配置 Rocky Linux 8.5 教程

    前言这是《VMware 虚拟机图文安装和配置 AlmaLinux OS 8.6 教程》一文的姐妹篇教程,如果你需要阅读它,请点击这里。2020 年,CentOS 宣布:计划未来将重…

    Linux 2023年6月7日
    0228
  • Docker如何镜像加速

    原文链接:https://www.zhoubotong.site/post/69.html在使用Docker 下载镜像时,如果不配置镜像加速,下载镜像会比较慢,因为国内从 Dock…

    Linux 2023年6月6日
    0143
  • eMule电骡使用教程

    eMule(电骡)是一个不错的下载器。实际上它是一个文件分享平台,但你可以把它当做一个自带资源搜索的bt下载器,如下图。虽然用户不多(我下午看在线有10万),下载速度一般,比较好的…

    Linux 2023年6月6日
    0150
  • 如何使用CMake构建c++项目

    1. c++项目构建与CMake简介 在Windows系统上我们通常使用 Visual Studio(VS)来生成我们的c++项目。我们只需在VS相应的层次目录中添加相应的文件即可…

    Linux 2023年6月14日
    0117
  • 前几天看到微信多开方式

    @echo offset wechatpath=WeChat.exeecho. echo. echo —————&#82…

    Linux 2023年6月14日
    0100
  • Lvs

    Lvs Lvs Lvs简介 体系结构 LVS管理工具 配置 lvs-nat 模式的 httpd 负载集群—http 配置lvs-nat模式的httpd负载集群&#821…

    Linux 2023年6月6日
    0126
  • k8s vs k3s: 差异解析

    2. K3s的优势 小型 K3s 的最大优势是它的尺寸最小(小于 100 MB),这有助于它以最少的设置在小型硬件中启动 Kubernetes 集群。 快速部署 curl -sfL…

    Linux 2023年6月13日
    0117
  • Jenkins+svn自动化部署完整教程

    1、概述 Jenkins 是一个可扩展的持续集成引擎。主要用于持续、自动地构建/测试软件项目、监控一些定时执行的任务。Jenkins用Java语言编写,可在Tomcat等流行的se…

    Linux 2023年6月7日
    096
  • 一劳永逸,解决.NET发布云服务器的时区问题

    国内大多数开发者使用的电脑,都是使用的北京时间,日常开发的过程中其实并没有什么不便;不过,等遇到了阿里云等云服务器,系统默认使用的时间大多为 UTC时间,这个时候,时区和时间的问题…

    Linux 2023年6月6日
    0100
  • Web Api单元测试写法

    例如我们在Web Api项目中有个Controller 如果你在单元测试中直接调用 SomeController 的Get()方法,那么你将会收到一个Exception提示Requ…

    Linux 2023年6月14日
    092
  • 设计模式——-建造者模式(生成器模式)

    建造者模式(生成器模式)定义:将一个复杂的对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。 建造者模式中的4个角色: Product产品类 通常是实现了模板方法模式…

    Linux 2023年6月7日
    0107
  • Windows下PowerShell监控Keepalived

    一、 背景 某数据库服务器为CentOS,想要监控Keepalived的VIP是否有问题,通过邮件进行报警,但这台机器不能上外网,现在只能在Windows下通过PowerShell…

    Linux 2023年5月28日
    0100
  • 20191223 实验一 密码引擎

    任务一 OpenEuler系统安装 1.登录自己的华为云账号,参考附件图示,构建基于鲲鹏和OpenEuler的ECS。或者通过使用树莓派安装OpenEuler,或者自己通过虚拟机安…

    Linux 2023年6月8日
    0107
  • Redis info参数总结(转)

    可以看到,info的输出结果是分几块的,有Servers、Clients、Memory等等,通过info后面接这些参数,可以指定输出某一块数据。 我刚开始在Gentoo上装的默认版…

    Linux 2023年5月28日
    0129
  • VS2022编译太慢

    解决方法是把编译出的exe程序或目录添加到杀毒软件白名单 一个C++的helloworld,在vs里硬是10秒才能编译启动。不知道大家有没有遇到。禁用符号加载还是很慢。甚至换成co…

    Linux 2023年6月6日
    0112
  • 前端数据提交给后端之HTML表单简单剖析

    写在开篇 什么是表单呢?当前端想要提交数据给后端,怎么搞?那么在前端开发中,表单是常用的手段,比如常见的场景有:登录框、账号注册页、主机信息录入CMDB等等场景都是需要表单。那么在…

    Linux 2023年6月7日
    0103
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球