news 2026/6/20 23:51:34

【ZAB协议】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【ZAB协议】

Multi-Paxos与ZAB协议的核心差异

Multi-Paxos仅能保证值一旦被选定后不再更改,但无法保证:

  • 选定值的内容是否符合业务逻辑(如必须先创建父节点)
  • 多个操作的执行顺序性(如X必须在Y之前执行)

ZAB协议通过以下设计解决这些问题:

  • 主节点(Leader)作为唯一提案者,避免并发提案
  • 为每个提案分配全局唯一且递增的事务ID(zxid)
  • 严格按zxid顺序提交提案

ZAB保证操作顺序性的关键机制

主节点唯一性
所有写请求必须由主节点处理,备份节点收到写请求时会转发给主节点。这避免了多节点并发提案导致的顺序混乱。

事务标识符(zxid)设计
zxid由两部分组成:

  • 高32位:epoch(任期编号),领导者变更时递增
  • 低32位:counter(计数器),同一任期内每个新提案递增

示例:

  • 第一个提案zxid为<1,1>
  • 第二个提案zxid为<1,2>
  • 新领导者上任后第一个提案zxid为<2,1>

顺序广播
主节点通过TCP协议按zxid顺序广播提案,确保:

  • 网络层保证消息先发先到
  • 节点接收提案的顺序与发送顺序一致

顺序提交
主节点必须按zxid顺序提交提案:

  • 只有前一个提案提交后,才会提交后一个提案
  • 即使提案Y先到达多数派,也必须等待提案X先提交

读写请求处理流程

写请求流程

  1. 客户端向任意节点发送写请求(如create /geekbang/time 456
  2. 备份节点将请求转发给主节点
  3. 主节点生成zxid并顺序广播提案
  4. 收到多数派确认后按zxid顺序提交
  5. 返回响应给客户端

读请求优化

  • 默认在任何节点都可读,但可能是稍旧数据
  • 需要强一致性读时,先执行sync命令同步最新状态

故障恢复场景示例

当主节点故障时:

  1. 新领导者选举会产生新的epoch
  2. 新领导者会收集所有未提交提案
  3. 按原zxid顺序重新提交这些提案
  4. 确保即使故障恢复后操作顺序不变

与Raft的对比

虽然ZAB和Raft都保证顺序性,但ZAB:

  • 更早提出(2007年 vs Raft的2013年)
  • 使用zxid而非term+index作为提案标识
  • 广播阶段设计更接近两阶段提交

实际应用验证

在ZooKeeper中创建嵌套节点的正确顺序:

create /geekbang123# 先创建父节点create /geekbang/time456# 再创建子节点

ZAB确保这两个操作会严格按顺序执行,避免出现子节点先于父节点创建的错误。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/17 1:15:04

【TCC分布式事务】

TCC实现指令原子性的原理 TCC&#xff08;Try-Confirm-Cancel&#xff09;通过三阶段操作实现业务层面分布式事务的原子性&#xff0c;其核心在于资源预留和状态管理的设计&#xff1a; Try阶段&#xff08;预留&#xff09; 对涉及的所有业务操作预先检查并预留资源&#xff0…

作者头像 李华
网站建设 2026/6/20 5:47:11

OpenCore Legacy Patcher终极指南:让老旧Mac重获新生的完整教程

还在为那些被Apple官方抛弃的老旧Mac发愁吗&#xff1f;看着2012年之前的MacBook、iMac无法升级到最新的macOS系统&#xff0c;是不是觉得它们已经走到了生命的尽头&#xff1f;别担心&#xff0c;OpenCore Legacy Patcher&#xff08;OCLP&#xff09;这款神奇的工具将彻底改变…

作者头像 李华
网站建设 2026/6/16 22:35:43

Mammoth.js:轻松将Word文档转换为HTML的完美解决方案

Mammoth.js&#xff1a;轻松将Word文档转换为HTML的完美解决方案 【免费下载链接】mammoth.js Convert Word documents (.docx files) to HTML 项目地址: https://gitcode.com/gh_mirrors/ma/mammoth.js 还在为Word文档的在线展示而烦恼吗&#xff1f;Mammoth.js正是你需…

作者头像 李华
网站建设 2026/6/18 13:29:34

Shutter Encoder深度解析:从技术架构到实战应用的完整指南

Shutter Encoder深度解析&#xff1a;从技术架构到实战应用的完整指南 【免费下载链接】shutter-encoder A professional video compression tool accessible to all, mostly based on FFmpeg. 项目地址: https://gitcode.com/gh_mirrors/sh/shutter-encoder 你是否曾经…

作者头像 李华
网站建设 2026/6/14 6:35:36

5分钟精通资源嗅探:零基础掌握跨平台下载神器终极指南

在日常网络冲浪中&#xff0c;你是否遇到过这样的困扰&#xff1a;想要保存喜欢的视频却发现无法下载&#xff1f;看到精彩的音频资源却束手无策&#xff1f;现在&#xff0c;这些问题都有了完美的解决方案。本文将带你深入了解一款功能强大的资源嗅探工具&#xff0c;让你轻松…

作者头像 李华
网站建设 2026/6/13 19:11:08

recaptcha v3 简单分析

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01;部分python代码cp execjs.compile(ope…

作者头像 李华