ZooKeeper是多主多从的结构,还是一主多从的结构?

文章内容收录到个人网站,方便阅读:hardyfish.top/

孙子兵法:

资料链接: url81.ctfile.com/f/57345181-...

访问密码:3899

Zookeeper 是 一主多从的结构。

具体来说,Zookeeper 集群由一个 Leader(主节点) 和多个 Follower(从节点) 构成,所有节点共同组成一个分布式协调服务。

以下是 Zookeeper 结构的详细说明:

1. Zookeeper 的一主多从架构

1.1 角色划分

  • Leader(主节点)

    • 负责处理所有的写请求(事务性请求,如创建节点、删除节点、更新数据)。
    • 确保写操作在所有节点上保持顺序一致性。
    • 负责协调集群的工作,包括管理心跳和故障检测。
    • 只有一个 Leader 节点。
  • Follower(从节点)

    • 负责处理读请求(非事务性请求,如获取节点数据)。
    • 接受 Leader 的指令,同步数据。
    • 参与选举过程,投票选举新的 Leader。
    • 有多个 Follower 节点。
  • Observer(观察者节点,可选)

    • 仅同步 Leader 的数据,但不参与选举和写操作投票。
    • 用于扩展读取能力,避免影响 Leader 的性能。
    • 适用于需要大量读操作的场景。

1.2 工作机制

  • 写请求

    1. 客户端将写请求发送到任意 Zookeeper 节点。
    2. 如果是 Follower 节点接收到写请求,它会转发给 Leader。
    3. Leader 将写请求转换为事务提案,并广播给所有 Follower。
    4. 多数 Follower(Quorum)确认提案后,Leader 将事务提交,并通知客户端。
  • 读请求

    1. 客户端可以向任意 Zookeeper 节点发送读请求。
    2. 读请求在 Follower 或 Leader 节点直接处理(视配置而定)。
    3. 读取的数据可能稍微滞后(非强一致性),但对于大多数场景足够使用。

2. 为什么是一主多从而不是多主

  1. 一致性保障

    • Zookeeper 强调 线性一致性,即所有写操作必须严格按顺序执行。
    • 多主结构会导致写冲突和一致性问题,一主多从可以通过 Leader 来保证全局的写顺序一致性。
  2. 性能权衡

    • 多主结构会增加写操作的协调成本(如冲突检测和合并),降低性能。
    • 一主多从通过集中管理写操作,简化了协调逻辑,同时利用从节点分担读操作压力。
  3. 选举机制

    • Zookeeper 使用基于 Zab 协议 的 Leader 选举机制,确保在 Leader 故障时,快速选出新的 Leader,维持服务可用性。

3. 一主多从的优缺点

优点

  1. 简单高效

    • 集中化的写操作管理,避免多主协调的复杂性。
    • 支持高并发读操作,从节点可以分担读取压力。
  2. 强一致性

    • 通过 Leader 控制写操作,确保所有节点的顺序一致性。
  3. 容错性

    • 只要超过一半的节点正常工作,集群就能保持服务。

缺点

  1. 写性能瓶颈

    • 所有写操作必须经过 Leader,Leader 的性能和带宽可能成为瓶颈。
  2. 单点故障

    • 如果 Leader 故障,尽管可以快速选出新 Leader,但会有短暂的服务中断。

4. 总结

Zookeeper 是 一主多从 的架构:

  • Leader 负责写请求,保证顺序一致性。
  • Follower 负责读请求,并同步 Leader 数据。
  • 通过这种架构,Zookeeper 在一致性和性能之间取得了平衡,适合协调分布式系统的状态。
相关推荐
武子康1 小时前
Java-80 深入浅出 RPC Dubbo 动态服务降级:从雪崩防护到配置中心秒级生效
java·分布式·后端·spring·微服务·rpc·dubbo
PAK向日葵1 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
舒一笑1 小时前
我的开源项目-PandaCoder迎来史诗级大更新啦
后端·程序员·intellij idea
@昵称不存在2 小时前
Flask input 和datalist结合
后端·python·flask
zhuyasen3 小时前
Go 分布式任务和定时任务太难?sasynq 让异步任务从未如此简单
后端·go
东林牧之3 小时前
Django+celery异步:拿来即用,可移植性高
后端·python·django
YuTaoShao3 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
源码_V_saaskw4 小时前
JAVA图文短视频交友+自营商城系统源码支持小程序+Android+IOS+H5
java·微信小程序·小程序·uni-app·音视频·交友
超浪的晨4 小时前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
AntBlack4 小时前
从小不学好 ,影刀 + ddddocr 实现图片验证码认证自动化
后端·python·计算机视觉