zookeeper内部原理 (进阶介绍 三)

目录

 ZooKeeper架构

Zab协议(Zookeeper Atomic Broadcast)

阶段一:Leader选举

阶段二:同步

阶段三:广播

数据结构

Watcher机制

会话管理

        会话超时

        临时节点

容错和高可用

        多数决策:

        数据复制:

        自动恢复:

 数据一致性保证


ZooKeeper内部原理主要围绕其核心组件和机制来展开,包括其架构、数据一致性协议(Zab协议)、Watcher机制等。以下是对ZooKeeper内部原理的详细解释:

 ZooKeeper架构

        ZooKeeper是一个分布式协调服务,其架构由以下几部分组成:

  • Client(客户端): 使用ZooKeeper API与ZooKeeper集群进行交互的应用程序。
  • Server(服务器): 组成ZooKeeper集群的节点,包括Leader、Follower和Observer。
  • Ensemble(集群): 由多个服务器节点组成的ZooKeeper集群,一般推荐使用奇数个节点。

Zab协议(Zookeeper Atomic Broadcast)

        Zab协议是ZooKeeper实现数据一致性和可靠性的核心协议,主要包括以下几个阶段:

阶段一:Leader选举

        当ZooKeeper集群启动或现有Leader失效时,集群需要进行Leader选举。Leader选举过程如下:

  • 每个节点向其他节点发送投票,推荐自己或认为合适的节点作为Leader。
  • 节点接收投票并统计,选出得票数过半的节点作为Leader。
  • Leader节点向所有Follower节点发送确认消息,Follower节点确认后,新的Leader就位。

阶段二:同步

        Leader选举完成后,Leader需要确保所有Follower节点的数据与自己保持一致,这个过程称为同步。同步过程如下:

  • Leader节点检查每个Follower节点的最新事务ID(zxid)。
  • Leader节点向Follower节点发送缺失的事务日志,直到所有节点的数据与Leader一致。

阶段三:广播

        当同步完成后,Leader开始处理客户端的事务请求(写操作)。广播过程如下:

  • 客户端发送写请求给Leader节点。
  • Leader节点生成事务提议(proposal),并将其广播给所有Follower节点。
  • Follower节点接收提议并写入本地事务日志,然后向Leader节点发送确认消息(ack)。
  • 当Leader节点收到超过半数Follower节点的确认消息时,提交事务,并向所有Follower节点发送提交消息(commit)。
  • Follower节点接收到提交消息后,应用事务并通知客户端。

数据结构

        ZooKeeper的命名空间是一个层次化的树状结构,每个节点称为znode。znode具有以下特性:

  • 数据存储:每个znode可以存储少量数据。
  • 元数据:每个znode包含元数据,如版本号、时间戳和子节点数量等。
  • 类型:znode可以是持久节点、临时节点或序列节点。

Watcher机制

        ZooKeeper提供了Watcher机制,用于监控znode的变化。Watcher机制如下:

  • 客户端可以在znode上注册Watcher。
  • 当znode发生变化(如数据变更、子节点变更或节点删除)时,ZooKeeper会触发Watcher,并通知注册了Watcher的客户端。
  • Watcher是一次性触发的,即每次触发后需要重新注册。

会话管理

ZooKeeper通过会话(session)来管理客户端连接和状态。会话具有以下特性:

        会话超时

        :每个会话都有一个超时时间,客户端需要在超时时间内保持与ZooKeeper服务器的连接。

        临时节点

        :由客户端创建的临时节点与会话相关联,当会话失效时,临时节点会被自动删除。

容错和高可用

        ZooKeeper通过以下机制实现容错和高可用:

        多数决策

                ZooKeeper采用多数决策(quorum)机制,确保即使部分节点故障,集群仍能正常工作。通常,集群由2F+1个节点组成,可以容忍F个节点故障。

        数据复制

                所有事务日志和数据都复制到多个节点,确保数据的可靠性和一致性。

        自动恢复

                当节点故障时,ZooKeeper能够自动进行Leader选举和数据同步,确保集群的正常运行。

 数据一致性保证

        ZooKeeper通过Zab协议和多数决策机制,确保了以下一致性特性:

        线性一致性

                所有事务请求按照全局顺序执行,确保数据的一致性。

        FIFO顺序

                来自同一客户端的请求按照发送顺序执行。

        最终一致性

                在没有新的更新操作时,所有节点的数据最终会达到一致。

  • 13
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值