开发者社区 > 数据库 > 正文

在分布式系统中领域中,日志复制的过程是怎样的?

已解决

在分布式系统中领域中,日志复制的过程是怎样的?

展开
收起
云上静思 2022-09-18 16:56:18 308 0
1 条回答
写回答
取消 提交回答
  • 推荐回答

    如下图所示,

    配图31.png

    当Leader 选举出来后,系统对外提供服务。Leader 接收客户端发来的请求,每个请求包含一个作用于副本状态机的命令。Leader 将每个请求封装成一个日志条目,追加到日志尾部,同时将这些日志条目按顺序并行地发送给Follower。每个日志条目都包含一个状态机命令和Leader 收到该请求时的当前任期号,此外还包括该日志条目在日志文件中的位置索引。当日志条目被安全地复制到多数节点,该日志条目被称为Committed,Leader 向客户端返回成功,并通知各个节点按照相同的顺序将日志条目中的状态机命令应用到复制状态机,此时该日志被称为Applied。

    可以看出,Raft 日志复制是一个Quorum 过程,能够容忍n / 2 - 1 个副本失败。Leader 会在后台为落后的副本补完日志。

    以上内容摘自《云原生数据库原理与实践》,这本书可以在电子工业出版社天猫店购买。

    2022-09-18 17:40:44
    赞同 展开评论 打赏

数据库领域前沿技术分享与交流

相关电子书

更多
PostgresChina2018_赖思超_PostgreSQL10_hash索引的WAL日志修改版final 立即下载
Kubernetes下日志实时采集、存储与计算实践 立即下载
日志数据采集与分析对接 立即下载