基于RabbitMQ的模拟消息队列之四——内存管理

文章目录

一、设计数据结构

针对交换机、队列、绑定、消息、待确认消息设计数据结构。

  • 交换机集合 exchangeMap

    数据结构:ConcurrentHashMap

    key:交换机name value:交换机对象

  • 队列集合 queueMap

    数据结构: ConcurrentHashMap

    key:队列name value:队列对象

  • 绑定集合 bindingsMap

    数据结构: ConcurrentHashMap 嵌套 ConcurrentHashMap

    key:交换机名字 value: ConcurrentHashMap <key:队列名字 value:绑定对象>

  • 消息集合 messageMap

    数据结构: ConcurrentHashMap

    key:messageId value:message对象

  • 队列消息集合

    数据结构 : ConcurrentHashMap 嵌套 LinkedList

    key:队列name value:LinkedList < Message >

  • 待确认消息集合

    数据结构: ConcurrentHashMap 嵌套 ConcurrentHashMap

    key:队列name value: ConcurrentHashMap < key:messageId value:Message对象>

二、管理集合

1.交换机

  • 往交换机集合中添加 Exchange 对象
  • 从交换机集合中删除Exchange 对象
  • 根据exchangeName查找Exchange对象

2.队列

  • 往队列集合中添加MSGQueue对象
  • 从队列集合中删除MSGQueue对象
  • 根据queueName查找MSGQueue对象

3.绑定

  • 往绑定集合中添加新绑定

  • 从绑定集合中删除绑定

  • 根据 exchangeName 和 queueName查找唯一的Binding 对象

  • 根据exchangeName查找该交换机的所有绑定关系

4.消息

  • 往消息集合中添加新消息
  • 从消息集合中删除消息
  • 根据messageId查找Message对象

5.队列上的消息

  • 往队列消息集合中发送消息

  • 从队列集合中取出消息

  • 统计队列上的消息总数

6.待确认消息

  • 往待确认集合中添加消息

  • 从待确认集合中删除消息

  • 根据messageId在待确认集合中查找Message对象

7.恢复数据

  • 将所有集合(除了待确认消息结合)清除
  • 从硬盘上加载交换机、队列、绑定、消息到内存
相关推荐
AlickLbc12 小时前
RabbitMQ安装记录
分布式·rabbitmq
pursue.dreams13 小时前
Windows 安装 RabbitMQ 保姆级教程
windows·rabbitmq
切糕师学AI2 天前
RabbitMQ 是什么?
微服务·消息队列·rabbitmq
Anastasiozzzz2 天前
解决 RabbitMQ 的可靠性投递与消息重复消费问题思路
分布式·rabbitmq
Ronin3052 天前
订阅者模块
rabbitmq
fchampion2 天前
最终一致性
java·spring·rabbitmq·github·mvc
予枫的编程笔记3 天前
【Kafka基础篇】RabbitMQ、RocketMQ、Kafka怎么选?3种主流MQ核心差异实测解析
kafka·rabbitmq·rocketmq·分布式流处理·发布订阅模型·消息队列(mq)·点对点模型
Ronin3054 天前
连接管理模块和服务器模块
服务器·rabbitmq·网络通信·tcp连接
Jinkxs5 天前
RabbitMQ - 第一个 Hello World 程序:SpringBoot 版极简集成
spring boot·rabbitmq·java-rabbitmq
希忘auto5 天前
详解RabbitMQ高级特性之延迟队列
rabbitmq