news 2026/6/12 5:35:09

【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/11 6:38:45

NotepadNext十六进制编辑功能终极指南:5大实战技巧深度解析

NotepadNext十六进制编辑功能终极指南&#xff1a;5大实战技巧深度解析 【免费下载链接】NotepadNext A cross-platform, reimplementation of Notepad 项目地址: https://gitcode.com/GitHub_Trending/no/NotepadNext 你是否曾遇到过需要直接编辑二进制文件却苦于没有合…

作者头像 李华
网站建设 2026/6/12 5:49:04

从零部署 OpenKM 文档管理系统:企业级文档管理实战指南

从零部署 OpenKM 文档管理系统&#xff1a;企业级文档管理实战指南 【免费下载链接】document-management-system OpenKM is a Open Source Document Management System 项目地址: https://gitcode.com/gh_mirrors/do/document-management-system 还在为团队文档管理混乱…

作者头像 李华
网站建设 2026/6/12 2:16:57

VC++运行库终极解决方案:一键修复Windows系统依赖问题

VC运行库终极解决方案&#xff1a;一键修复Windows系统依赖问题 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist 问题引爆&#xff1a;真实案例中的DLL缺失痛点 …

作者头像 李华
网站建设 2026/6/10 14:28:38

Umi-OCR技术架构深度解析:插件化引擎与多场景应用实战

Umi-OCR技术架构深度解析&#xff1a;插件化引擎与多场景应用实战 【免费下载链接】Umi-OCR Umi-OCR: 这是一个免费、开源、可批量处理的离线OCR软件&#xff0c;适用于Windows系统&#xff0c;支持截图OCR、批量OCR、二维码识别等功能。 项目地址: https://gitcode.com/GitH…

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

六音音源修复版终极指南:3步解决洛雪音乐播放问题

六音音源修复版终极指南&#xff1a;3步解决洛雪音乐播放问题 【免费下载链接】New_lxmusic_source 六音音源修复版 项目地址: https://gitcode.com/gh_mirrors/ne/New_lxmusic_source 还在为洛雪音乐升级后无法正常播放音乐而烦恼吗&#xff1f;六音音源修复版为您提供…

作者头像 李华
网站建设 2026/6/12 20:17:27

数字孪生系统的测试验证方法体系研究

1. 数字孪生技术特性与测试挑战 1.1 技术架构复杂性 数字孪生作为物理实体的虚拟映射&#xff0c;其系统架构包含数据采集层、模型构建层、仿真分析层和决策应用层四个核心层级。测试人员需要面对多源异构数据融合、物理模型与数据模型耦合、实时性要求高等特殊挑战。特别是在…

作者头像 李华