项目实战 — 消息队列(5){统一硬盘操作}

前面已经使用数据库管理了交换机、绑定、队列,然后又使用了数据文件管理了消息。

那么,这里就创建一个类,讲之前的两个部分整合起来,对上层提供统一的一套接口,表示硬盘上存储的所有的类的信息。

java 复制代码
/*
* 用这个类来管理所有硬盘上的数据
* 1.数据库:交换机、绑定、队列
* 2.数据文件:消息
* */
public class DiskDataCenter {
//    用这个示例来管理数据库中的数据
    private DataBaseManger dataBaseManger = new DataBaseManger();
//    用这个表示数据文件中的数据
    private MessageFileManger messageFileManger = new MessageFileManger();

    public void init(){
//        针对上述的两个示例进行初始化
        dataBaseManger.init();
        messageFileManger.init();
    }


    /*封装数据库操作*/
//    封装交换机操作
    public void insertExchange(Exchange exchange){
        dataBaseManger.insertExchange(exchange);
    }

    public void deleteExchange(String exchangeName){
        dataBaseManger.deleteExchange(exchangeName);
    }

    public List<Exchange> selectAllExchanges(){
        return dataBaseManger.selectAllExchanges();
    }

//    封装队列操作
    public void insertQueue(MSGQueue queue) throws IOException {
        dataBaseManger.insertQueue(queue);
//        创建队列的同时,不仅需要把队列对象写道数据库中,还需要创建出对应的目录和文件
        messageFileManger.createQueueFiles(queue.getName());
    }

    public void deleteQueue(String queueName) throws IOException {
        dataBaseManger.deleteQueue(queueName);
//        删除队列的同时,不仅需要把队列对象从数据库中删除,还需要删除出对应的目录和文件
        messageFileManger.destroyQueueFiles(queueName);
    }

    public List<MSGQueue> selectAllQueues(){
        return dataBaseManger.selectAllQueues();
    }

//    封装绑定操作
    public void insertBinding(Binding binding){
        dataBaseManger.insertBinding(binding);
    }

    public void deleteBinding(Binding binding){
        dataBaseManger.deleteBinding(binding);
    }

    public List<Binding> selectAllBindings(){
        return dataBaseManger.selectAllBindings();
    }


    /*封装消息操作*/
//    发送操作
    public void sendMessage(MSGQueue queue, Message message) throws IOException, MqException {
        messageFileManger.sendMessage(queue,message);
    }

//    删除操作
    public void deleteMessage(MSGQueue queue,Message message) throws IOException, ClassNotFoundException, MqException {
        messageFileManger.deleteMessage(queue, message);
        if (messageFileManger.checkGC(queue.getName())){
            messageFileManger.gc(queue);
        }
    }

//    将信息加载到内存
    public LinkedList<Message> loadAllMessageFromQueue(String queueName) throws IOException, MqException, ClassNotFoundException {
        return messageFileManger.loadAllMessageFromQueue(queueName);
    }

}

创建了这个类,我们就不用去直接调用DataBaseManager和MessageFileManager里面得方法了。

相关推荐
用户128526116028 小时前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java
Linsk8 小时前
组件 = 模板 + 业务逻辑
java·前端·vue.js
星沉远浦9 小时前
用Gemini高效解决Java代码报错难以定位的问题
java
用户2986985301412 小时前
Word 文档字符级格式化:Java 实现方案详解
java·后端
笨鸟飞不快13 小时前
从单个服务到集群:一次完整的性能排查复盘
java·前端
荣码13 小时前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
SamDeepThinking13 小时前
Java微服务练习方式
java·后端·微服务
朦胧之1 天前
AI 编程-老项目改造篇
java·前端·后端
程序猿大帅1 天前
别再只当调包侠了:用 Spring AI 落地 Function Calling,我被大模型硬生生砸出了三个大坑
java
程序员晓琪1 天前
约定大于配置:基于 Java 包名自动生成 API 版本路由的最佳实践
java·spring boot·后端