【項目篇之統一硬盤操作】仿照RabbitMQ模擬實現消息隊列

在這里插入圖片描述

統一硬盤操作

    • 創建出實例
    • 封裝交換機的操作
    • 封裝隊列的操作
    • 封裝綁定的操作
    • 封裝消息的操作
    • 總的完整代碼:

我們之前已經使用了數據庫去管理交換機,綁定,隊列

還使用了數據文件去管理消息

此時我們就搞一個類去把上述兩個部分都整合在一起,對上層提供統一的一套接口

在項目文件中的datacenter這個包下面創建一個新的類:DiskDataCenter

使用這個類來管理所有的硬盤上的數據:
一個是數據庫:交換機,綁定,隊列
一個是數據文件:消息
上層邏輯如果需要操作硬盤,統一都通過這個類來使用(上層代碼不在乎當前數據是在數據文件中還是數據庫中)

創建出實例

我們先去創建出數據庫實例和數據文件的實例:

 //把數據庫實例創建出來  private DataBaseMapper dataBaseMapper = new DataBaseMapper();  //把數據文件的實力創建出來  private MessageFileManager messageFileManager = new MessageFileManager();  

接著對這兩個實例進行初始化:

//初始化方法:針對上面的兩個實例進行初始化  public void init(){  dataBaseMapper.init();  //下面這個是空的方法,后續要擴展再寫  messageFileManager.init();  } 

封裝交換機的操作

我們這里是使用剛剛創建出來的數據庫的實例dataBaseMapper去封裝了插入交換機,刪除交換機,查詢交換機:

//封裝交換機的三個操作  //插入交換機  public void insertExchange(Exchange exchange){  dataBaseMapper.insertExchange(exchange);  }  //刪除交換機  public void deleteExchange(String exchangeName){  dataBaseMapper.deleteExchange(exchangeName);  }  //查詢交換機  public List<Exchange> selectAllExchanges(){  return dataBaseMapper.selectAllexchanges();  }  

封裝隊列的操作

我們這里是使用剛剛創建出來的數據庫的實例dataBaseMapper去封裝了插入隊列,刪除隊列,查詢隊列:

//封裝隊列的三個操作  //插入隊列  public void insertQueue(MSGQueue queue){  dataBaseMapper.insertQueue(queue);  }  //刪除隊列  public void deleteQueue(String queueName){  dataBaseMapper.deleteQueue(queueName);  }  //查詢隊列  public List<MSGQueue> selectAllQueue(){  return dataBaseMapper.selectAllQueues();  }  

封裝綁定的操作

我們這里是使用剛剛創建出來的數據庫的實例dataBaseMapper去封裝了插入綁定,刪除綁定,查詢綁定:

//封裝綁定的三個操作  //插入綁定  public void insertBinding(Binding binding){  dataBaseMapper.insertBinding(binding);  }  //刪除綁定  public void deleteBinding(Binding binding){  dataBaseMapper.deleteBinding(binding);  }  //查詢綁定  public List<Binding> selectAllBindings(){  return dataBaseMapper.selectAllBindings();  }  

封裝消息的操作

我們這里是使用剛剛創建出來的數據文件的實例messageFileManager去封裝了發送消息,刪除消息,加載隊列中的所有消息:

//封裝消息操作  //發送消息  public void sendMessage(MSGQueue queue, Message message) throws IOException, MqException {  messageFileManager.sendMessage(queue,message);  }  //刪除消息  //考慮刪除了之后,多了一個無效消息,看看是不是要進行垃圾回收  public void deleteMessage(MSGQueue queue, Message message) throws IOException, ClassNotFoundException, MqException {  messageFileManager.deleteMessage(queue,message);  if(messageFileManager.checkGC(queue.getName())){  messageFileManager.gc(queue);  }  }  //加載隊列中的所有消息public LinkedList<Message> loadAllMessageFromQueue(String queueName) throws IOException, MqException, ClassNotFoundException {  return messageFileManager.loadAllMessageFromQueue(queueName);  }

總的完整代碼:

這個DiskDataCenter類的總代碼如下所示:

package org.example.mqtexxt.mqserver.datacenter;  import org.example.mqtexxt.common.MqException;  
import org.example.mqtexxt.mqserver.core.Binding;  
import org.example.mqtexxt.mqserver.core.Exchange;  
import org.example.mqtexxt.mqserver.core.MSGQueue;  
import org.example.mqtexxt.mqserver.core.Message;  import java.io.IOException;  
import java.util.LinkedList;  
import java.util.List;  /*  
使用這個類來管理所有的硬盤上的數據:  
一個是數據庫:交換機,綁定,隊列  
一個是數據文件:消息  
上層邏輯如果需要操作硬盤,統一都通過這個類來使用(上層代碼不在乎當前數據是在數據文件中還是數據庫中)  */public class DiskDataCenter {  //把數據庫實例創建出來  private DataBaseMapper dataBaseMapper = new DataBaseMapper();  //把數據文件的實力創建出來  private MessageFileManager messageFileManager = new MessageFileManager();  //初始化方法:針對上面的兩個實例進行初始化  public void init(){  dataBaseMapper.init();  //下面這個是空的方法,后續要擴展再寫  messageFileManager.init();  }  //封裝交換機的三個操作  //插入交換機  public void insertExchange(Exchange exchange){  dataBaseMapper.insertExchange(exchange);  }  //刪除交換機  public void deleteExchange(String exchangeName){  dataBaseMapper.deleteExchange(exchangeName);  }  //查詢交換機  public List<Exchange> selectAllExchanges(){  return dataBaseMapper.selectAllexchanges();  }  //封裝隊列的三個操作  //插入隊列  public void insertQueue(MSGQueue queue){  dataBaseMapper.insertQueue(queue);  }  //刪除隊列  public void deleteQueue(String queueName){  dataBaseMapper.deleteQueue(queueName);  }  //查詢隊列  public List<MSGQueue> selectAllQueue(){  return dataBaseMapper.selectAllQueues();  }  //封裝綁定的三個操作  //插入綁定  public void insertBinding(Binding binding){  dataBaseMapper.insertBinding(binding);  }  //刪除綁定  public void deleteBinding(Binding binding){  dataBaseMapper.deleteBinding(binding);  }  //查詢綁定  public List<Binding> selectAllBindings(){  return dataBaseMapper.selectAllBindings();  }  //封裝消息操作  //發送消息  public void sendMessage(MSGQueue queue, Message message) throws IOException, MqException {  messageFileManager.sendMessage(queue,message);  }  //刪除消息  //考慮刪除了之后,多了一個無效消息,看看是不是要進行垃圾回收  public void deleteMessage(MSGQueue queue, Message message) throws IOException, ClassNotFoundException, MqException {  messageFileManager.deleteMessage(queue,message);  if(messageFileManager.checkGC(queue.getName())){  messageFileManager.gc(queue);  }  }  //加載隊列中的所有消息public LinkedList<Message> loadAllMessageFromQueue(String queueName) throws IOException, MqException, ClassNotFoundException {  return messageFileManager.loadAllMessageFromQueue(queueName);  }
}

DiskDataCenter類主要就是去封裝了消息的基本操作,其實也就是把之前的MessageFileManager類和DataBaseMapper類的關鍵方法統一進行了封裝操作

后續的代碼中,上層代碼就不用直接去調用MessageFileManager類和DataBaseMapper類了

上層代碼而是直接去調用這個DiskDataCenter類即可

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/82128.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/82128.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/82128.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

快速上手SpringBoot開發指南

文章目錄 1. 項目整體架構2. SpringBoot核心注解詳解2.1 應用程序入口注解SpringBootApplication 2.2 控制器層注解RestControllerRequestMappingPostMappingRequestBody 2.3 服務層注解ServiceAutowired 2.4 數據訪問層注解Repository 2.5 實體類注解JPA相關注解Lombok注解 3.…

Unity WebGL、js發布交互

官網參考 Unity3D開發之WebGL平臺上 unity和js前端通信交互 WebFun.jslib mergeInto(LibraryManager.library, {JSLog: function (str) { var strsUTF8ToString(str); Log(str); Log(strs);}, Hello: function () {var strs"Hello, world!"; Log(strs); Log(UTF8ToS…

Spark 之 YarnCoarseGrainedExecutorBackend

YarnCoarseGrainedExecutorBackend executor ID , 在日志里也有體現。 25/05/06 12:41:58 INFO YarnCoarseGrainedExecutorBackend: Successfully registered with driver 25/05

[HOT 100] 2646. 最小化旅行的價格總和

文章目錄 1. 題目鏈接2. 題目描述3. 題目示例4. 解題思路5. 題解代碼6. 復雜度分析 1. 題目鏈接 2646. 最小化旅行的價格總和 - 力扣&#xff08;LeetCode&#xff09; 2. 題目描述 現有一棵無向、無根的樹&#xff0c;樹中有 n 個節點&#xff0c;按從 0 到 n - 1 編號。給你一…

分析 Docker 磁盤占用

以下是分析 Docker 磁盤占用的詳細步驟和工具指南&#xff0c;幫助開發者快速定位和清理冗余數據&#xff1a; 1. 查看 Docker 磁盤使用概覽 docker system df 輸出說明&#xff1a; TYPE TOTAL ACTIVE SIZE RECLAIMABLE Images 15 …

聊一聊接口測試中的參數化測試

目錄 一、核心概念 二、適用場景 三、參數化測試的核心目的 四、實現參數化測試的關鍵步驟 4.1 定義測試數據 4.2 使用測試框架參數化功能 4.3 執行測試與結果分析 五、最佳實踐與注意事項 六、工具推薦 那參數化測試的目的是什么&#xff1f;應該是為了提高測試覆蓋率…

Go語言——string、數組、切片以及map

一、string、數組、切片代碼 package mainimport "fmt"// 定義結構體 type student struct {id intname stringage intscore float32 }func main() {// 使用var聲明切片var slice1 []intslice1 append(slice1, 1)slice1 append(slice1, 2)slice1 append(sl…

Android 開發中JDK 的使用和配置詳解

前些天發現了一個蠻有意思的人工智能學習網站,8個字形容一下"通俗易懂,風趣幽默",感覺非常有意思,忍不住分享一下給大家。 ??點擊跳轉到教程 在安卓開發中, 我們會使用到Java的JDK, JDK全程為(Java Development Kit)意思是:Java開發工具包。那么JDK 與我們的…

MPay碼支付系統第四方聚合收款碼多款支付插件個人免簽支付源碼TP8框架全開源

一、源碼描述 這是一套碼支付源碼&#xff08;MPay&#xff09;&#xff0c;基于TP8框架&#xff0c;前端layui2.9后端PearAdmin&#xff0c;專注于個人免簽收款&#xff0c;通過個人的普通收款碼&#xff0c;即可實現收款通知自動回調&#xff0c;支持絕大多數商城系統&#…

國產數據庫鑄就數字基建新基石,助力農業產業轉型升級

中國科技企業以自主創新突破技術壁壘&#xff0c;為全球產業鏈重構注入新動能。廣東辰宜信息科技有限公司&#xff08;以下簡稱“辰宜科技”&#xff09;憑借自主研發的“博流分布式多模數據庫”等核心技術&#xff0c;作為支持數據流通的關鍵技術支撐&#xff0c;實現中國基礎…

《人工智能:如何重塑教育模式與學習圖景》

《人工智能&#xff1a;如何重塑教育模式與學習圖景》 引言 人工智能&#xff0c;特別是大型語言模型&#xff08;如GPT-4/ChatGPT&#xff09;&#xff0c;正以前所未有的速度影響教育領域。從基礎教育到高等教育&#xff0c;再到職業教育&#xff0c;傳統教學模式正在被重新審…

硬件工程師面試常見問題(14)

第六十六問&#xff1a;運放--輸入偏置電流和輸入失調電流 輸入偏置電流lb&#xff1a;是由于運放兩個輸入極都有漏電流的存在。實際的運放,會有電流流入運放的輸入端的。那么輸入偏置電流就定義這兩個電流的平均值。 輸入失調電流 Ios&#xff1a;定義為兩個差分輸入端偏置電…

Docker+Kubernetes落地指南:從單機到集群的平滑遷移

一、為何必須升級到Kubernetes&#xff1f; 1.1 單機Docker的瓶頸 單機環境痛點&#xff1a; ├─ 資源利用率不均衡&#xff08;CPU飆高 vs 內存閑置&#xff09; ├─ 服務擴容需手動操作 ├─ 零宕機更新難以實現 └─ 網絡配置復雜&#xff08;跨主機通信困難&am…

HttpPrinter 是一款功能強大的跨平臺 Web 打印解決方案

HttpPrinter 是一款功能強大的跨平臺 Web 打印解決方案&#xff0c;支持多種編程語言和打印場景&#xff0c;適用于企業級報表打印、靜默打印、遠程打印等需求。以下是其核心功能、技術特點及使用方法的綜合分析&#xff1a; 一、核心功能與特點 跨平臺與多語言支持 支持 Java…

Selenium Web自動化測試學習筆記(一)

自動化測試 技術手段模擬人工&#xff0c;執行重復性任務&#xff0c;準確率100%&#xff0c;高于人工 selenium 可通過瀏覽器驅動控制瀏覽器&#xff0c;通過元素定位模擬人工&#xff0c;實現web自動化&#xff0c;沒有焦點&#xff08;把瀏覽器放在最小化依然可以&#x…

TikTok 矩陣運營新手實操保姆級教程 2.0 版本

在當下這個全球化的數字浪潮中&#xff0c;TikTok 這片充滿機遇的流量藍海&#xff0c;正吸引著無數創業者和品牌方爭相角逐。而要想在這激烈的競爭中脫穎而出&#xff0c;TikTok 矩陣運營無疑是至關重要的制勝法寶。今天&#xff0c;就給大家送上這份超實用的新手實操教程&…

使用DeepSeek協助恢復歷史數據

最近&#xff0c;工作中遇到比較老的數據庫備份文件數據恢復的問題。過程中使用DeepSeek分析&#xff0c;很快的解決了從除備份文件本身其他信息一概不知的條件下&#xff0c;數據庫選型問題和環境搭建問題。下面把實施過程分享出來&#xff0c;給其他遇到相同問題的小伙伴提供…

【特殊場景應對6】頻繁跳槽:行業特性與穩定性危機的解釋邊界

寫在最前 作為一個中古程序猿,我有很多自己想做的事情,比如埋頭苦干手搓一個低代碼數據庫設計平臺(目前只針對寫java的朋友),比如很喜歡幫身邊的朋友看看簡歷,講講面試技巧,畢竟工作這么多年,也做到過高管,有很多面人經歷,意見還算有用,大家基本都能拿到想要的offe…

企業智能化第一步:用「Deepseek+自動化」打造企業資源管理的智能中樞

隨著Deepseek乃至AI人工智能技術在企業中得到了廣泛的關注和使用&#xff0c;多數企業開始了AI探索之旅&#xff0c;迅易科技也不例外&#xff0c;且在不斷地實踐中強化了AI智能應用創新的強大能力。 為解決企業知識管理碎片化、提高內部工作效率等問題&#xff0c;迅易將目光放…

大連理工大學選修課——圖形學:第三四章 基本圖形生成算法

第三四章 基本圖形生成算法 圖形生成 概念&#xff1a;如何在指定的輸出設備上&#xff0c;根據坐標描述&#xff0c;構造基本二維幾何圖形 基本二維幾何圖形&#xff1a;點、直線、圓、多邊形域、字符串及相關屬性等。 圖形生成的概念 是在指定的輸出設備上&#xff0c;根…