共识算法Raft系列(1)——什么是Raft?

Raft 算法是一种分布式一致性算法,由 Diego Ongaro 和 John Ousterhout 在 2014 年提出,旨在解决 Paxos 算法复杂且难以理解的问题。Raft 设计目标是易于理解和实现,同时提供强一致性(CAP 中的 CP 系统),广泛应用于分布式系统中,如 etcd、Consul 和 TiDB。以下是对 Raft 算法的详细解释,包括其原理、流程、角色、优缺点及应用场景。

1. Raft 算法概述

  • 目标:在分布式系统中达成共识,确保多个节点在不可靠网络环境中对某个值(如日志条目、状态更新)达成一致。
  • 核心思想:通过 Leader 驱动的日志复制机制实现共识,将问题分解为易于理解的子任务:Leader 选举、日志复制和安全保证。
  • 前提假设
    • 节点可能崩溃(非拜占庭故障),但不会恶意行为。
    • 网络可能出现延迟、分区或消息丢失,但最终可达。
    • 至少多数节点(>50%)正常运行以达成共识。

2. Raft 的角色

Raft 中每个节点在任意时刻处于以下三种角色之一:

  1. Leader(领导者)
    • 负责处理客户端请求、协调日志复制、向 Follower 发送心跳。
    • 系统中最多只有一个活跃 Leader。
  2. Follower(跟随者)
    • 被动接收 Leader 的心跳和日志复制请求。
    • 可响应投票请求,参与 Leader 选举。
  3. Candidate(候选者)
    • 临时角色,节点在选举新 Leader 时进入此状态。
    • 发起投票请求,尝试成为 Leader。

与 Paxos 的对比

特性 Raft Paxos
易理解性 高,分解为选举和复制子问题 低,流程复杂,难以实现
角色 Leader、Follower、Candidate Proposer、Acceptor、Learner
一致性 强一致性(CP 系统) 强一致性(CP 系统)
性能 Leader 驱动,单点瓶颈 Multi-Paxos 优化后性能相近
应用 etcd、Consul、TiDB Google Spanner、Chubby、ZooKeeper
相关推荐
上进小菜猪8 小时前
当时序数据不再“只是时间”:金仓数据库如何在复杂场景中拉开与 InfluxDB 的差距
后端
程序员zgh8 小时前
C++ 互斥锁、读写锁、原子操作、条件变量
c语言·开发语言·jvm·c++
鲨莎分不晴8 小时前
强化学习第五课 —— A2C & A3C:并行化是如何杀死经验回放
网络·算法·机器学习
盖世英雄酱581369 小时前
springboot 项目 从jdk 8 升级到jdk21 会面临哪些问题
java·后端
搞科研的小刘选手9 小时前
【ISSN/ISBN双刊号】第三届电力电子与人工智能国际学术会议(PEAI 2026)
图像处理·人工智能·算法·电力电子·学术会议
拉姆哥的小屋9 小时前
从混沌到秩序:条件扩散模型在图像转换中的哲学与技术革命
人工智能·算法·机器学习
Sammyyyyy9 小时前
DeepSeek v3.2 正式发布,对标 GPT-5
开发语言·人工智能·gpt·算法·servbay
程序猿DD9 小时前
JUnit 5 中的 @ClassTemplate 实战指南
java·后端
sin_hielo10 小时前
leetcode 2110
数据结构·算法·leetcode
Jay200211110 小时前
【机器学习】33 强化学习 - 连续状态空间(DQN算法)
人工智能·算法·机器学习