Lind.DDD.LindQueue的一些想法

来源:http://www.cnblogs.com/lori/archive/2016/11/23/6094320.html
-Advertisement-
Play Games

回到目錄 很久就想寫一套屬於自己的消息隊列組件,前段時候看了湯雪華同學的EQueue,感覺還是不錯的,他也是看了rabbitMQ之後寫的Equeue,在設計上與前者有類似的地方,而大叔這次準備寫一個LindQueue,當前整體架構都差不多,無非是生產者,管道,消費者三個角色,而核心部分就是管道Bro ...


回到目錄

很久就想寫一套屬於自己的消息隊列組件,前段時候看了湯雪華同學的EQueue,感覺還是不錯的,他也是看了rabbitMQ之後寫的Equeue,在設計上與前者有類似的地方,而大叔這次準備寫一個LindMQ,當前整體架構都差不多,無非是生產者,管道,消費者三個角色,而核心部分就是管道Broker這個東西了,為生產者提供了push操作;而為消費者又提供了Pull操作;為瞭解耦考慮,他們之前沒有直接的引用關係,通訊採用tcp的方式,Broken的消息存儲介質我們使用redis,生產者和消費者與Broker的通訊我們採用FastSocket這個組件。

LindMQ設計架構圖

關於MQ系統的三大對象

以下三大對象其實都有各自的實現,各自的平臺,各自也都需要一個宿主!

Producer

生產者,用來將消息從源平臺發送到目標隊列中,目標隊列用到存儲消息,這裡一般指Broker,它可以是一種集群環境,它會封裝對存儲消息介質的入隊與出隊的基本操作,而對於真實的存儲介質,生產者是不需要知道的!

Broker

消息處理者,用來處理消息,加工消息,存儲消息等,它會公開基本的推消息介面和拉消息介面!

Consumer

消費者,用來處理Broker里的消息,它一般通過長連接,定時向Broker裡拉消息的方法實現,基於實時性考慮,又出現了pub/sub這種發佈與訂閱模式,當消費方訂閱了某種消息主題(topic)之後,有這種消息產生時,broker會把消息自動推到消息方!

關於消息的上下文

消息上下文,我們可以把它看成是承載消息的對象,它會有topic主題,queueId消息隊列索引,queueOffset內容索引,body消息體組成,它相關於是producer,broker和consumer之間定義的一種數據協議,他們之間通訊使用這種公開的協議,在LinqQueue裡面消息協議我們稱為LindMQ,下麵看一下協議的內容

    /// <summary>
    /// 消息協議
    /// </summary>
    [Serializable]
    public class LindMQ
    {
        /// <summary>
        /// 消息所屬Topic,每種Topic有一種類型的Body
        /// </summary>
        public string Topic { get; set; }
        /// <summary>
        /// 消息內容,Redis里存儲為Json
        /// </summary>
        public string Body { get; set; }
        /// <summary>
        /// 消息所屬的隊列ID
        /// </summary>
        public int QueueId { get; internal set; }
        /// <summary>
        /// 消息在所屬隊列的序號
        /// </summary>
        public long QueueOffset { get; internal set; }
        /// <summary>
        /// 消息的存儲時間
        /// </summary>
        internal DateTime CreateTime { get; set; }
        /// <summary>
        /// 將消息對象序列化成字元
        /// </summary>
        /// <returns></returns>
        public override string ToString()
        {
            return Utils.SerializeMemoryHelper.SerializeToJson<LindMQ>(this);
        }
    }

通過上面代碼我們可以看到,Topic,QueueId,QueueOffset,Body等欄位,這也是一個消息協議也需要的主要信息了,Topic是消息主題,我們可以這樣認為,一種主題就是一類消息,QueueId它位於Topic消息主題下麵,一個topic可以包括多個queue,而QueueOffset是每個queue里的消息索引,類似你的消息在消息隊列里排在第幾位;而body就是我們的消息體了,它使用二時制流表示,這樣有利於網路傳輸!

好了,今天主要是對LinqQueue做一個簡單的介紹,下次我再繼續介紹LindQueue!

回到目錄

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一.OGNL的概念 OGNL是Object-Graph Navigation Language的縮寫,全稱為對象圖導航語言,是一種功能強大的表達式語言,它通過簡單一致的語法,可以任意存取對象的屬性或者調用對象的方法,能夠遍歷整個對象的結構圖,實現對象屬性類型的轉換等功能。 Struts 2支持以下幾 ...
  • HTTP Status 500 - Wrapper cannot find servlet class com.servlet.servlet.RegServlet or a class it depends on type Exception report message Wrapper cann ...
  • C語言是我們大多數人的編程入門語言,對其也再熟悉不過了,不過很多初學者在學習的過程中難免會出現迷茫,比如:不知道C語言可以開發哪些項目,可以應用在哪些實際的開發中……,這些迷茫也導致了我們在學習的過程中不知道如何學、學什麼,所以,總結這個列表,希望對C語言初學者可以有所幫助~ C語言可以做什麼? 從 ...
  • 什麼是Hibernate? Hibernate是基於ORM(O:對象,R:關係,M:映射)映射的持久層框架,是一個封裝JDBC的輕量級框架,主要實現了對資料庫的CUPD操作。 註:CRUD是指在做計算處理時的增加(Create)、查詢(Retrieve)(重新得到數據)、更新(Update)和刪除( ...
  • 學習這個東西挺奇怪的,時間一長就容易忘記,或者記不清楚。今天看到一些UML圖的關係,發現有些出入了,索性就寫下來,以後再忘記的時候過來看看。 在UML的類圖中,常見的有以下幾種關係: 繼承(Generalization), 實現(Realization), 關聯(Association), 依賴(D ...
  • 今天講單例設計模式,這種設計模式和工廠模式一樣,用的非常非常多,同時單例模式比較容易的一種設計模式。 一、什麼是單例設計模式 單例模式,也叫單子模式,是一種常用的軟體設計模式。在應用這個模式時,單例對象的類必須保證只有一個實例存在。 二、單例模式的技巧 三、單例模式的應用場景 資料庫設計,我們發送一 ...
  • 設計模式;一個程式員對設計模式的理解:“不懂”為什麼要把很簡單的東西搞得那麼複雜。後來隨著軟體開發經驗的增加才開始明白我所看到的“複雜”恰恰就是設計模式的精髓所在,我所理解的“簡單”就是一把鑰匙開一把鎖的模式,目的僅僅是著眼於解決現在的問題,而設計模式的“複雜”就在於它是要構造一個“萬能鑰匙”,目的 ...
  • 原網站:C# Entity Framework併發處理 在軟體開發過程中,併發控制是確保及時糾正由併發操作導致的錯誤的一種機制。從 ADO.NET 到 LINQ to SQL 再到如今的 ADO.NET Entity Framework,.NET 都為併發控制提供好良好的支持方案。併發處理方式一般分 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...