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

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.dtcms.com/a/203362.html

相关文章:

  • PySide6 GUI 学习笔记——常用类及控件使用方法(常用控件调色板QPalette)
  • 【LUT技术专题】DnLUT代码解读
  • 进程——概念及状态
  • NHANES最新指标推荐:NHR
  • DP2 跳台阶【牛客网】
  • win版mysql8.0和redis,解压即用
  • YOLO模型初次训练体验(+实测)
  • 时态--07--过去完成時
  • 探秘「4+3原型驱动的交付模式」如何实现软件快速定制
  • 现代计算机图形学Games101入门笔记(十八)
  • 《算法笔记》11.8小节——动态规划专题->总结 问题 B: 拦截导弹
  • 第二届帕鲁杯时间折叠(TimeFold Paradox)
  • 2025年电工杯新规发布-近三年题目以及命题趋势
  • vLLM框架高效原因分析
  • 游戏开发实战(三):Python复刻「崩坏星穹铁道」嗷呜嗷呜事务所---源码级解析该小游戏背后的算法与设计模式【纯原创】
  • 【优秀三方库研读】在 quill 开源库中为什么封装 safe_fwrite,而不是直接使用系统 fwrite
  • Unity3D仿星露谷物语开发47之砍树时落叶特效
  • 四元数中 w xyz 的含义及应用
  • 一文掌握 LoRA 常见变体
  • Ubuntu操作系统里面安装Docker Compose
  • 大模型高效微调技术全面解析:从PEFT原理到实战应用
  • 简单理解 LightRAG
  • 力扣-快乐数
  • leetcode hot100刷题日记——6.和为 K 的子数组
  • 【Java微服务组件】异步通信P1—消息队列基本概念
  • 【Linux】第二十三章 控制启动过程
  • 高版本Fastjson:Getter调用限制及绕过方式探究
  • python学习day3
  • Linux 磁盘扩容实战案例:从问题发现到完美解决
  • idea部署本地仓库和连接放送远程仓库