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

Zookeeper 在 Kafka 中扮演了什么角色?

在 Apache Kafka 的早期架构中,ZooKeeper 扮演了分布式协调服务角色,负责管理和协调整个 Kafka 集群。 尽管新版本的 Kafka 正在逐步移除对 ZooKeeper 的依赖,但在许多现有和较早的系统中,了解 ZooKeeper 的作用仍然非常重要。

ZooKeeper 在 Kafka 中的核心角色包括:

  • 集群成员管理(Broker 注册): Kafka 集群中的每个 Broker(节点)在启动时都会向 ZooKeeper 注册自己的信息,例如 IP 地址和端口。 这种注册通常是临时的,意味着如果一个 Broker 宕机或与 ZooKeeper 的连接断开,它注册的节点就会被自动删除。 这使得集群中的其他组件能够动态地感知到 Broker 的加入或离开。

  • 控制器选举(Controller Election): 集群中会有一个 Broker 被选举为“控制器”,负责管理分区的状态、副本的分配以及处理 Broker 的故障转移。 ZooKeeper 负责这一选举过程,确保在任何时候集群中只有一个活跃的控制器,避免了“脑裂”问题。

  • 元数据存储: ZooKeeper 是 Kafka 集群元数据的权威存储中心。 这包括:

    • Topic 配置信息: 关于每个 Topic 的分区数量、副本因子、配置覆盖等信息都存储在 ZooKeeper 中。
    • 分区和副本状态: ZooKeeper 记录了每个分区的 Leader 副本是哪个 Broker,以及哪些 Broker 是 Follower 副本(ISR,In-Sync Replicas)。
    • 消费者组信息: ZooKeeper 存储了每个消费者组消费的 Topic,以及每个分区被哪个消费者消费的对应关系。
  • 负载均衡: 生产者和消费者客户端通过监听 ZooKeeper 中的节点变化,来动态地发现 Broker 列表和 Topic 的分区信息。 当有新的 Broker 加入或有 Broker 宕机时,客户端能够及时获取最新的集群状态,从而实现生产和消费的负载均衡。

  • 消费进度记录(Offset 存储): 在旧版本的 Kafka 中,消费者会将其消费每个分区的进度(Offset)定期提交到 ZooKeeper 中进行存储。 这确保了消费者在重启或重新分配分区后,可以从上次消费的位置继续处理消息。不过,新版本的 Kafka 已经将 Offset 的存储移到了 Kafka 内部的一个名为 __consumer_offsets 的 Topic 中。

  • 访问控制列表(ACLs): Kafka 的安全访问控制列表信息也存储在 ZooKeeper 中,用于管理客户端的读写权限。

未来趋势:移除 ZooKeeper

从 Kafka 2.8.0 版本开始,社区通过 KIP-500 提案引入了基于 Raft 协议的内置共识机制(称为 KRaft),目标是完全移除对 ZooKeeper 的依赖。 在这种新模式下,Kafka 集群自己管理元数据,从而简化了部署和运维,并提高了可扩展性和性能。

http://www.xdnf.cn/news/18080.html

相关文章:

  • CVPR 2025|英伟达联合牛津大学提出面向3D医学成像的统一分割基础模型
  • 决策树总结
  • CloudBase AI ToolKit + VSCode Copilot:打造高效智能云端开发新体验
  • 在 CentOS 7 上使用 LAMP 架构部署 WordPress
  • CSS:水平垂直居中
  • Java基础(九):Object核心类深度剖析
  • GPT-5在辅助论文写作方面,有哪些进步?
  • 10CL016YF484C8G Altera FPGA Cyclone
  • 千岑智能亮相CIVS2025:国产仿真平台突破技术壁垒,赋能智能汽车产学研融合
  • 【GM3568JHF】FPGA+ARM异构开发板烧录指南
  • 制作全流程对比:侗家灰水粽VS布依族草灰粽的8道工序差异
  • 项目实战——矿物识别系统(利用机器学习从化学元素数据中识别矿物,从数据到分类模型)
  • Linux系统等保三级安全加固执行手册(ReahtCentosKylin)
  • Android中flavor的使用
  • (第十八期)图像标签的三个常用属性:width、height、border
  • 【iOS】锁的原理
  • SIGKDD-2023《Complementary Classifier Induced Partial Label Learning》
  • Unity2022打包安卓报错的奇葩问题
  • Win11安装WSL、Docker Desktop
  • 【最后203篇系列】033 Mongo副本集修复过程
  • 【论文阅读】-《GeoDA: a geometric framework for black-box adversarial attacks》
  • 如何在 Ubuntu 24.04 安装 Python 3.12 ?
  • C语言篇:猜数字游戏的实现教程
  • 【图像算法 - 17】慧眼识“果”:基于深度学习与OpenCV的苹果智能检测系统(附完整代码)
  • 【Linux系统】进程间通信:System V IPC——消息队列和信号量
  • 「三维共振」:重构实体零售的破局模式
  • HTML应用指南:利用POST请求获取上海黄金交易所金价数据
  • 折扣大牌点餐api接口对接适合本地生活吗?
  • OVS:除了Geneve和VXLAN,还有哪些虚拟化网络协议?
  • OpenCV Python——Numpy基本操作(Numpy 矩阵操作、Numpy 矩阵的检索与赋值、Numpy 操作ROI)