当前位置: 首页 > article >正文

共识算法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 的对比

特性RaftPaxos
易理解性高,分解为选举和复制子问题低,流程复杂,难以实现
角色Leader、Follower、CandidateProposer、Acceptor、Learner
一致性强一致性(CP 系统)强一致性(CP 系统)
性能Leader 驱动,单点瓶颈Multi-Paxos 优化后性能相近
应用etcd、Consul、TiDBGoogle Spanner、Chubby、ZooKeeper
http://www.lryc.cn/news/2401815.html

相关文章:

  • JS逆向爬虫教程与实战技巧
  • Neovim - LSP 底层原理,难点配置(二)
  • 【Redis】Redis 的常见客户端汇总
  • 关于akka官方quickstart示例程序(scala)的记录
  • 2025年渗透测试面试题总结-腾讯[实习]玄武实验室-安全工程师(题目+回答)
  • 网站首页菜单两种布局vue+elementui顶部和左侧栏导航
  • AWS之迁移与传输服务
  • @Builder的用法
  • Unity3D 逻辑代码性能优化策略
  • 【Python Cookbook】文件与 IO(二)
  • vue实现点击按钮input保持聚焦状态
  • [蓝桥杯]取球博弈
  • Spring Security入门:创建第一个安全REST端点项目
  • [Java 基础]数组
  • fastadmin fildList 动态下拉框默认选中
  • java学习笔记——数组和二维数组
  • ‘pnpm‘ 不是内部或外部命令,也不是可运行的程序
  • Android Test2 获取系统android id
  • webpack打包学习
  • 基于Java(Jsp+servelet+Javabean)+MySQL实现图书管理系统
  • 服务器CPU被WMI Provider Host系统进程占用过高,导致系统偶尔卡顿的排查处理方案
  • JavaSwing之--JMenuBar
  • vue3+elementplus表格表头加图标及文字提示
  • 【物联网-S7Comm协议】
  • NLP中的input_ids是什么?
  • LeetCode Hot100刷题——划分字母区间
  • c++ 基于OpenSSL的EVP接口进行SHA3-512和SM3哈希计算
  • Vue3实现拖拽改变元素大小
  • Spring IoC 详解:原理、实现与实战
  • 深入Java NIO:构建高性能网络应用