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

Rocketmq Broker与队列关系,怎么存储的

RocketMQ Broker与队列关系图解说明

基本概念

在RocketMQ中,Broker是消息存储和转发的核心组件,而队列(Queue)是消息存储的基本单位。理解它们之间的关系对于设计高效的消息系统至关重要。

关系图解

复制

下载

+---------------------+
|      Broker         |
|  +---------------+  |
|  |   Topic A     |  |
|  | +-----------+ |  |
|  | | Queue 0   | |  |
|  | +-----------+ |  |
|  | +-----------+ |  |
|  | | Queue 1   | |  |
|  | +-----------+ |  |
|  | +-----------+ |  |
|  | | Queue 2   | |  |
|  | +-----------+ |  |
|  +---------------+  |
|                     |
|  +---------------+  |
|  |   Topic B     |  |
|  | +-----------+ |  |
|  | | Queue 0   | |  |
|  | +-----------+ |  |
|  | +-----------+ |  |
|  | | Queue 1   | |  |
|  | +-----------+ |  |
|  +---------------+  |
+---------------------+

关键点说明

  1. 一个Broker包含多个Topic

    • 每个Broker可以存储多个Topic的消息

  2. 一个Topic包含多个Queue

    • 每个Topic在Broker中被划分为多个Queue(默认4个)

    • Queue是消息存储和消费的最小单位

  3. 队列分布示例

复制

下载

Topic: OrderTopic
- Broker A- Queue 0- Queue 1
- Broker B- Queue 2- Queue 3

生产消费关系

  1. 生产者发送消息

    • 消息会被路由到Topic下的某个Queue

    • 路由策略可以是轮询、哈希等

  2. 消费者消费消息

    • 消费者组从Queue中拉取消息

    • 同一个消费者组内的消费者分摊Queue的消费

实际部署示例

复制

下载

集群部署:
+------------+       +------------+
| Broker A   |       | Broker B   |
| - Topic1   | <---> | - Topic1   |
|   - Queue0 |       |   - Queue1 |
|   - Queue2 |       |   - Queue3 |
| - Topic2   |       | - Topic2   |
|   - Queue0 |       |   - Queue1 |
+------------+       +------------+

重要特性

  1. 队列数量决定并行度

    • 更多队列意味着更高的生产消费并行度

  2. 队列是持久化的

    • 队列中的消息会持久化到磁盘

  3. 主从复制以队列为单位

    • 每个队列在主从之间同步数据

理解Broker与队列的关系有助于合理设计Topic和队列数量,优化消息系统的性能和可靠性。

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

相关文章:

  • AI语音合成平台:AnKo开启免费创作新时代!
  • 基于Telink 8258配合Wireshark抓包测试SIG Mesh的IV Index Update过程
  • Java基础 Day16
  • leetcode hot100:四、解题思路大全:滑动窗口(无重复字符的最长子串、找到字符串中所有字母异位词)、子串(和为k的子数组、)
  • Mysql刷题 day07
  • 苍穹外卖系统结构与功能报告
  • 飞致云旗下开源项目GitHub Star总数突破150,000个
  • 集成运算放大器知识汇总
  • js如何复制图片
  • 嘉立创EDA成图:原理图绘制以及PCB封装导出为.efoo文件
  • 用于管理共享内存的 C# 类 ShareMemory
  • Python 训练营打卡 Day 30
  • SpringBoot实现本地对象存储【minio、阿里云、七牛云】
  • Python-多进程编程 (multiprocessing 模块)
  • 101个α因子#6
  • P2670 [NOIP 2015 普及组] 扫雷游戏
  • 使用VGG-16模型来对海贼王中的角色进行图像分类
  • 【CodeBuddy 】从0到1,打造一个“牛马打鸡血仪”
  • C++ 初阶 | 类和对象易错知识点(上)
  • leetcode2310. 个位数字为 K 的整数之和-medium
  • Python字符串切片详解
  • Oracle中如何解决FREE BUFFER WAITS
  • Modbus通信协议详解
  • 字典和哈希表(javascript版)
  • 水利数据采集MCU水资源的智能守护者
  • 使用VMWare安装的ubuntu虚拟机,突然无法上网.
  • 鸿蒙应用开发:应用运行到设备报错,可能是版本问题,可通过hdc查询设备API版本
  • 第8天-Python趣味绘图:用Turtle库开启绘画编程之旅
  • tcpdump抓包
  • Nuxt的SEO实践