RocketMQ 的存储结构是怎样的?

参考答案

消息存储是 MQ 消息队列中最为复杂和最为重要的一部分。

消息生产者发送消息到 Broker ,会按照顺序存储在 CommitLog 文件中,每个 CommitLog 文件的大小为 1G 。

如图所示:

RocketMQ 的存储结构是怎样的?

RocketMQ 的几个主要组件说明:

  • Commit Log:存储所有的消息元数据,包括 Topic、QueueId 以及 message
  • CosumerQueue:消费逻辑队列,存储消息在 CommitLog 的 offset
  • IndexFile- 索引文件:存储消息的 key 和时间戳等信息,使得 RocketMQ 可以采用 key 和时间区间来查询消息

RocketMQ 将消息均存储在 CommitLog 中,并分别提供了 CosumerQueue 和 IndexFile 两个索引,来快速检索消息。

 

以上,是消息队列 RocketMQ 面试题【RocketMQ 的存储结构是怎样的?】的参考答案。

输出,是最好的学习方法

欢迎在评论区留下你的问题、笔记或知识点补充~

—end—

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧