mq消息存储
Posted lccsblog
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mq消息存储相关的知识,希望对你有一定的参考价值。
- comitlog文件
- ConsumerQueue文件
- IndexFile文件
RocketMQ将所有主题的消息存储在同一个文件中,确保消息发送时顺序写文件。
为了提高消息消费的效率RocketMQ引入了ConsumeQueue消息队列文件,每个消息主题包含一个多个消息消费队列,每一个消费队列有一个消费文件。消息到达CommitLog文件后,将异步转发到消息消费队列
为了加速消息的检索性能,引入IndexFile索引文件,根据消息的属性快速从Commitlog文件中检索消息。存储消息Key与Offset的对应关系。
- messageStoreConfig消息存储配置属性
- commitLog文件的存储实现类
- consumeQueueTable消息队列缓存列表,按消息主题分组
- flushConsumeQueueService消息队列文件ConsumeQueue刷盘线程
- cleanCommitLogService清除CommitLog文件服务
- cleanConsumeQueueService 清除ConsumeQueue文件服务
- indexService 索引文件实现类
- allocateMappedFileService MappedFile分配服务
- reputMessageService commitLog消息分发,根据CommitLog文件构建ConsumeQueue,IndexFile。
- haService存储HA机制
- transientStorePool消息堆内存缓存
- MessageArrivingListener 消息拉去长轮询模式达到监听器
- brokerConfig。Broker配置属性
- storeCheckpoint 文件刷盘检查点
- dispatcherList。CommitLog文件转发请求
以上是关于mq消息存储的主要内容,如果未能解决你的问题,请参考以下文章