Rocketmq的整体认识

前言

上文已经介绍了分布式消息队列的常见概念,从本文开始,将分多篇文章逐步对RocketMQ这款分布式消息队列的架构,功能,以及不同功能的源码实现原理进行分析。本文主要是介绍RocketMQ的功能,架构,加深对RocketMQ的认识。

RocketMQ是什么?

Rocketmq是由阿里巴巴2012年开源的分布式消息中间件,现在已经是apache顶级项目。他是一个队列模型的消息中间件,具有高性能、高可靠、高实时、分布式特点。它借鉴了kafka的实现,在kafka基础上丰富了更多的功能,并且提高了堆积消息能力和稳定性。Producer、Consumer、队列都可以分布式部署。Producer 向一些队列轮流发送消息,队列集合称为 Topic,Consumer 如果做广播消费,则一个 consumer实例消费这个 Topic 对应的所有队列,如果做集群消费,则多个 Consumer 实例平均消费这个队列集合。

Rocketmq的组成和整体架构

由producer,consumer,broker,namesever组成。其中Producer 负责生产消息,Consumer 负责消费消息,Broker 负责存储消息,nameserver负责topic路由信息管理。

各个组件的部署图:

各个组件的交互图:

总结:

1、每个组成部分都可以集群部署,具备横向扩展分布式能力

2、生产者,消费者,broker都需要和nameserver保持通信,nameserver之间不通信

Rocketmq的功能和特性

1、支持顺序消息,能够保证严格的消息顺序

2、提供丰富的消息拉取模式

3、高效的订阅者水平扩展能力

4、实时的消息订阅机制

5、亿级消息堆积能力

6、较少的依赖,自己实现了nameserver,不需要像kafka一样依赖zookeeper

Rocketmq的存储结构

commitLog是文件,用于存储消息内容。

ConsumerQueue是逻辑队列,消费者和生产者都是通过consumerQueue查找到具体的commitlog再操作存取消息的。

索引文件提供查询消息的能力,可以根据消息key,时间戳查询消息

Rocketmq和Kafka的比较

下面是官网给出的对比图。

相比Kafka,RocketMQ有更多的功能(ps: 这问题面试也经常被问到)

1、支持定时消息,定时消息使用场景比较多。

2、发送消息既支持同步也支持异步

3、支持广播消费模式

4、支持可视化管理台对消息topic,broker进行管理

5、更低的延迟

6、支持消息轨迹,可以在控制台查看消息轨迹

总结

本文主要介绍Rocket的组成,架构,和kafka的功能异同,从整体上对Rocketmq的认识。后续文章将对Rocketmq的功能特性进行介绍,并对实现原理进行分析。

相关推荐
mqiqe20 小时前
K8S 算力架构
容器·架构·kubernetes
LiRuiJie20 小时前
深入剖析RocketMQ
java·rocketmq
努力学算法的蒟蒻20 小时前
day63(1.22)——leetcode面试经典150
算法·leetcode·面试
廋到被风吹走20 小时前
【消息队列】选型深度对比:Kafka vs RocketMQ vs RabbitMQ
kafka·rabbitmq·rocketmq
YE1234567_20 小时前
从底层零拷贝到分布式架构:深度剖析现代 C++ 构建超大规模高性能 AI 插件引擎的实战之道
c++·分布式·架构
CTO Plus技术服务中21 小时前
强悍的Go语言开发面试题和答案
java·面试·职场和发展
英雄史诗21 小时前
系统边界定义与模块拆分原则的成功落地案例
微服务·架构
Lonely丶墨轩21 小时前
AI 对话系统 - DeepSeekClient 技术架构详解
人工智能·架构
OpenBayes21 小时前
Nemotron Speech ASR低延迟英文实时转写的语音识别服务;GLM-Image开源混合自回归与扩散解码架构的图像生成模型
人工智能·深度学习·机器学习·架构·数据集·语音识别·图像编辑
智源研究院官方账号21 小时前
技术详解 | 众智FlagOS1.6:一套系统,打通多框架与多芯片上下适配
人工智能·驱动开发·后端·架构·硬件架构·硬件工程·harmonyos