Kafka 再也不须要 ZooKeeper

img

Kafka 2.8.0 出炉了,此版本有一项重大改进:安全

实现了 Raft 分布式一致性机制,意味着能够脱离 ZooKeeper 独立运行了。

ZooKeeper 在 Kafka 中扮演着重要的角色,用来存储 Kafka 的元数据。less

ZooKeeper 存储着 Partition 和 Broker 的元数据 ,同时也负责 Kafka Controller 的选举工做。分布式

对于 Kafka 来说,ZooKeeper 是一套外部系统,要想部署一套 Kafka 集群,就要同时部署、管理、监控 ZooKeeper。工具

ZooKeeper 有本身的配置方式、管理工具,和 Kafka 彻底不同,因此,一块儿搞两套分布式系统,天然就提高了复杂度,也更容易出现问题。有时工做量还会加倍,例如要开启一些安全特性,Kafka 和 ZooKeeper 中都须要配置。spa

除了复杂度,外部存储也会下降系统效率code

例如 Kafka 集群每次启动的时候,Controller 必须从 ZooKeeper 加载集群的状态信息。rem

再好比选举出一个新的 Controller 以后也会比较麻烦,由于须要加载元数据,而此时元数据的量可能已经很是大了,这就产生了效率问题。部署

因此,ZooKeeper 带来的复杂度、系统效率这两个问题已经成为 Kafka 的痛点,Kafka 团队一直在努力去除对 ZooKeeper 的依赖。Kafka 2.8.0 这个版本终于实现了。产品

使用 Raft 模式以后,元数据、配置信息都会保存在 @metadata 这个 Topic 中,自动在集群中复制。这样 Kafka 就会简单轻巧不少。it

但须要注意的是,Zookeeper-less Kafka 还属于早期版本,并不完善,因此,如今不要应用在线上产品环境中。

相关文章
相关标签/搜索