RabbitMQ 模拟实现【二】:模块划分

文章目录

模块划分

消息队列模块设计

公共模块

  • 通信协议:为了实现客户端和服务器之间的通信,来完成的逻辑,基于 TCP 实现的自定义的应用层协议.通过这个协议,完成客户端-服务器 远程方法的调用
  • 序列化/反序列化:消息往往需要转化为二进制来便于转发,此处是把类对象 =>二进制的数据序列。反序列化反之

服务器模块

虚拟主机:为了便于简单实现,此处只支持一个虚拟主机,但是按道理来讲要有多个虚拟主机,类似于MySQL中的database,整合一系列相关的业务数据

虚拟主机模块

  • 硬盘管理:
    • 将每一种数据用以HashMap为主的数据结构来管理,以保证能有足够高的效率来实现消息队列
    • 交换机、队列、绑定这几个部分使用数据库进行管理,相对来说这几个部分增删改查要多一些,因此利用数据库来实现数据的管理
    • 消息部分使用文件管理,消息通常不需要过多的增删改查,通常也会涉及到较大的内容,数据库性能也有限,因此使用文件管理更合适一些
    • 无论是数据库还是文件,我们最终都存储到硬盘里,以防重启以后数据丢失,保证数据持久化
  • 内存管理:
    • 在使用时需要从硬盘加载到内存中,便于高效率的API实现
  • 消息转发:
    • 主要由不同交换机对应不同的转发规则

客户端模块:

主要实现通过TCP与服务器建立联系,通过远程调用服务器API来实现用户需求


TIP:

此处应当实现核心类:Exchange,MSGQueue,Bingding,Message(交换机、队列、绑定、文件)

相关推荐
填满你的记忆1 分钟前
MCP协议是什么?为什么它被称为AI时代的“USB接口”?
java·人工智能·agent·mcp
云烟成雨TD2 分钟前
Spring AI Alibaba 1.x 系列【72】集成 MCP 客户端
java·人工智能·spring
独隅5 分钟前
Visual Studio Code 和 Visual Studio 2026 两大开发工具的核心差异
java·vscode·visual studio
我登哥MVP6 分钟前
SpringCloud 核心组件解析:服务注册与发现
java·spring boot·后端·spring·spring cloud·java-ee·maven
ZHECSDN10 分钟前
Java模板方法模式:缓存操作重复写?把骨架抽出来
java·模板方法模式
傅科摆 _ py11 分钟前
AI Ping 平台使用教程
java·前端·人工智能
风味蘑菇干19 分钟前
JDBC(数据库连接池&DBUtils)
java·数据库
Chengbei1123 分钟前
CTF & 红队专用 AI 求解AI 引擎 Cairn 系统,化轻量化部署,红队、CTF、漏洞研究一站式解决方案
java·人工智能·安全·web安全·网络安全·系统安全
墨白曦煜24 分钟前
算法实战笔记:空间换时间的黑魔法——单调栈全景解析(十一)
java·笔记·算法
AI玫瑰助手31 分钟前
Python函数:函数的文档字符串(docstring)编写
android·java·python