看完这篇文章告诉你RocketMQ为什么要放弃Zookeeper?

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: 一位7年工作经验的小伙伴去面架构师岗位,被问到这样一道面试题,说”RocketMQ为什么要放弃Zookeeper“。然后,想了很久好像没关注过,也不敢瞎猜。那么今天,我给大家来聊一聊我对这个问题的理解。

一位7年工作经验的小伙伴去面架构师岗位,被问到这样一道面试题,说”RocketMQ为什么要放弃Zookeeper“。然后,想了很久好像没关注过,也不敢瞎猜。


那么今天,我给大家来聊一聊我对这个问题的理解。

1、注册中心

36fd9a9541fe6dabeebb81df8804f405.png

对于分布式消息中间件而言,当不同的消息存储在不同的Broker上,生产者和消费者对于Broker的选取,路由选择会面临以下几个问题:


1、生产者发一条消息,应该发到哪个Broker?消费者接收消息,从哪个Broker获取消息?


2、如果Broker增加或者减少了,客户端怎么知道?


3、一个新的生产者或者消费者加入,如何感知?


所以,只要是跟分布式服务调用的场景,都需要一个注册中心,在RocketMQ当然也中需要有一个这样的角色来管理Broker的信息。

644a2776d24aecd416111eee6c715e36.png

而Kafka就是用了现成的Zookeeper,但是RocketMQ却偏偏没有这么做,而是自己实现了一个服务,这个服务叫做NameServer。


我们可以把NameServer理解为是RocketMQ的路由中心,每一个NameServer节点都保存了全量的路由信息。为了保证高可用,NameServer自身也可以做集群的部署。它的作用有点像Eureka或者Redis的Sentinel。


也就是说,Broker会在NameServer上注册自己,Porducer和Consumer用NameServer来发现Broker。

c206f15cdfc1b0c1e30a04437528c679.png

每个Broker节点在启动时,都会根据配置遍历NameServer列表。


与每个NameServer建立TCP长连接,注册自己的信息,之后每隔30s发送心跳信息。


如果Broker挂掉了,不发送心跳了,NameServer怎么发现呢?


所以,除了主从注册,还有定时探活。每个NameServer每隔10s检查一下各个Broker的最近一次心跳时间,如果发现某个Broker超过120s都没发送心跳,就认为这个Broker已经挂掉了,会将其从路由信息里移除。

2、放弃理由

既然,Nameserver的作用也是用来管理Broker的服务的,也就是服务注册与发现,那为什么不直接用Zookeeper、Consul、etcd、Eureka这样的组件呢?


实际上在RocketMQ的早期版本中,跟Kafka一样也是用Zookeeper实现服务管理的,但到RokcetMQ开源的时候去掉了ZooKeeper依赖,转而采用自己的NameServer。

42ff3607ad8e533c412b516f4e844dfa.png

因为,RocketMQ是一个保持最终一致性的架构设计,它架构决定了它只需要一个轻量级的元数据服务器就足够了,而不需要像Zookeeper这样的强一致性解决方案。不依赖另一个中间件,从而减少整体维护成本。

3b40c5cccb838de3a517c8d179d7b474.png

根据著名的CAP理论,在一致性(Consistency)、可用性(Availability)、分区容错性(Partiton Tolerance)中,Zookeeper实现了CP,而NameServer选择了AP,放弃了实时一致性。


以上就是我对RocketMQ为什么要放弃Zookeeper的理解!

我是被编程耽误的文艺Tom,关注我,面试不再难!

ee90d9963df444db88b33d6e798a5b94.gif

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
相关文章
|
消息中间件 存储 分布式计算
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(二)
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(二)
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(二)
|
消息中间件 负载均衡 Kafka
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(三)
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(三)
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(三)
|
消息中间件 存储 负载均衡
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(一)
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(一)
一篇文章把RabbitMQ、RocketMQ、Kafka三元归一(一)
|
Java Apache 开发工具
一篇文章带你入门Zookeeper
Zookeeper是什么 官方文档上这么解释zookeeper,它是一个分布式服务框架,是Apache Hadoop 的一个子项目,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务、状态同步服务、集群管理、分布式应用配置项的管理等。
2589 0
|
存储 消息中间件 中间件
读懂这篇文章,你的阿里技术面就可以过关了 | Apache RocketMQ 101
在美国的大学课程中,101是所有课程中的第一门,是新生入学后的必修课程。阿里巴巴中间件技术专家刘振东在上周的Apache RocketMQ开发者沙龙北京站的活动上,进行了主题为《ApacheRocketMQ 101》的分享,帮助开发者从0开始学习 Apache RocketMQ,除了一些基础的入门内容外,还有很多是在社区未发表过的个人所感所悟,首次对外分享。
5798 0
|
3月前
|
消息中间件 JSON Java
开发者如何使用轻量消息队列MNS
【10月更文挑战第19天】开发者如何使用轻量消息队列MNS
141 6
|
3月前
|
消息中间件 安全 Java
云消息队列RabbitMQ实践解决方案评测
一文带你详细了解云消息队列RabbitMQ实践的解决方案优与劣
107 10
|
2月前
|
消息中间件 存储 Kafka
MQ 消息队列核心原理,12 条最全面总结!
本文总结了消息队列的12个核心原理,涵盖消息顺序性、ACK机制、持久化及高可用性等内容。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。