告別繁瑣!1分鐘帶你構建RabbitMQ消息應用

来源:https://www.cnblogs.com/digital-college/p/18075317
-Advertisement-
Play Games

支持.Net/.Net Core/.Net Framework,可以部署在Docker, Windows, Linux, Mac。 RabbitMQ作為一款主流的消息隊列工具早已廣受歡迎。相比於其它的MQ工具,RabbitMQ支持的語言更多、功能更完善。 1.發送消息、獲取消息、使用消息 本文提供一 ...


支持.Net/.Net Core/.Net Framework,可以部署在Docker, Windows, Linux, Mac。

RabbitMQ作為一款主流的消息隊列工具早已廣受歡迎。相比於其它的MQ工具,RabbitMQ支持的語言更多、功能更完善。

1.發送消息、獲取消息、使用消息

本文提供一種市面上最/極簡單的使用RabbitMQ的方式,只需要會調用以下三個方法,你就幾乎可以掌握整個RabbitMQ的使用:

(1)     SendMessage,發送一個消息

(2)     GetMessage,獲取一個消息

(3)     UseMessage,使用一個消息(連續使用)

 

為了調用以上三個方法,首先需要從NuGet引用DeveloperSharp.RabbitMQ包。

然後,對RabbitMQ消息伺服器的鏈接信息進行配置(分.Net Core與.Net Framework兩種情況):

若是在.Net Core環境下,你則需要在DeveloperSharp.json文件中添加“DeveloperSharp.RabbitMQ”節點(如下配置示例),並把DeveloperSharp.json文件放到程式執行目錄中(即bin目錄下與dll、exe等文件的同一目錄中,放錯了位置會報錯)(註意:有些.Net Core版本在Visual Studio“調試”時,不會在bin目錄下生成全部的dll、exe,此時需要把此配置文件放在應用程式的“根目錄”下)。

{
  "DeveloperSharp.RabbitMQ":[{
    "HostName":"135.208.12.236",
    "VirtualHost":"/",
    "UserName":"sa",
    "Password":"aevin.gang",
    "Port":5672
  }]
}

 

若是在.Net Framework環境下,你則需要在App.config/Web.config裡面添加如下配置:

  <appSettings>
    <add key="RabbitMQConnectionString" value="hostName=135.208.12.236,virtualHost=/,port=5672,userName=sa,password=aevin.gang" />
  </appSettings>

說明:上述配置中分別設置了RabbitMQ應用所在的伺服器IP地址hostName、虛擬主機virtualHost、埠port、用戶名userName、密碼password(請把這五項的對應值修改成你自己那邊的RabbitMQ的對應值)

 

下麵,我們給出一個使用了上述SendMessage、GetMessage、UseMessage三個方法的示例。該示例的功能說明如下:

  • 先向RabbitMQ伺服器上名為“aa”的隊列發送了5個消息,
  • 然後從RabbitMQ伺服器上的“aa”隊列中獲取,並列印出第1個消息,
  • 最後再連續從RabbitMQ伺服器上的“aa”隊列中獲取剩餘4個消息,並把它們寫入名為fj.txt的文件。

代碼如下:

using DeveloperSharp.RabbitMQ;
--------------------------

        static void Main(string[] args)
        {
            //發送5個消息(使用SendMessage)
            RabbitMQHelper.SendMessage("aa", "世界1,你好!");
            RabbitMQHelper.SendMessage("aa", "世界2,你好!");
            RabbitMQHelper.SendMessage("aa", "世界3,你好!");
            RabbitMQHelper.SendMessage("aa", "世界4,你好!");
            RabbitMQHelper.SendMessage("aa", "世界5,你好!");

            //獲取1個消息(使用GetMessage)
            string OneMessage = RabbitMQHelper.GetMessage("aa").Message;
            Console.WriteLine(OneMessage);

            //向fj.txt這個文本文件中寫入4個消息(使用UseMessage)
            RabbitMQHelper.UseMessage("aa", t => 
            {
                System.IO.File.AppendAllText("D:/fj.txt", t.Message);
                return true;
            });
        }

運行結果如下:

【控制台顯示出】:世界1,你好!

【fj.txt文件中顯示出】:世界2,你好!世界3,你好!世界4,你好!世界5,你好!

 

(上述示例中,由於SendMessage是同步方法,故“世界1,你好!”~“世界5,你好!”會按順序顯示。若我們把SendMessage方法全部改為非同步的SendMessageAsync,則顯示結果將不再是按順序來的,很有可能顯示成類似這樣:“世界3,你好!世界1,你好!世界5,你好!世界2,你好!世界4,你好!”)

 

三個方法的詳細功能說明(輔助參考):

1)發送一個消息
void SendMessage(string QueueName, string Message, Dictionary<string, object> Header = null)
//非同步方法:SendMessageAsync
2)獲取一個消息
RabbitMQMessage GetMessage(string QueueName)
//非同步方法:GetMessageAsync
3)使用一個消息(連續使用)
void UseMessage(string QueueName, Func<RabbitMQMessage, bool?> Use)
//非同步方法:UseMessageAsync
附加說明:
    (I)Use返回值為true時,代表當前消息已被有效處理並會被伺服器刪除。然後程式自動進入下一條消息的使用。
         若Use返回值為false時,代表當前消息未被有效處理但仍會被伺服器刪除。然後程式自動進入下一條消息的使用。
         若Use返回值為null時,代表當前消息會被伺服器重新隊列分配到其它可用的實例上再處理。然後程式自動進入下一條消息的使用。
         若Use內部發生未被處理的異常,程式會停止。
    (II)RabbitMQMessage對象定義如下:
          public class RabbitMQMessage
          {
             public string Message;
             public IDictionary<string, object> Header;
             public string Id; //此處系統自動生成的Id是分散式唯一Id。
          }

最後說明一點:一旦調用三個方法,會與RabbitMQ伺服器建立“長鏈接”。若要結束“長鏈接”,可在“任務管理器”中殺死進程。

 

2.延時隊列 & 死信隊列

有些場景下,我們希望為使用的消息設定有效期。在有效期內,這些消息有效可用;但過期後,這些消息將變得無效不可用,同時,它們還將自動被丟棄進一個稱之為“死信”的隊列。

為了說明這些概念,我們還是來舉一個具體的例子。該例子的功能說明如下:

  • 首先,在RabbitMQ伺服器上定義一個名為"bbq"、且其中存放的消息會在60秒後過期失效的隊列。
  • 然後,在RabbitMQ伺服器上定義一個與"bbq"隊列對應的死信隊列。並連續從該死信隊列中獲取消息並把它們寫入名為BB.txt的文件。
  • 最後,向RabbitMQ伺服器上的"bbq"隊列發送3個消息。

 代碼如下:

using DeveloperSharp.RabbitMQ;//從NuGet引用DeveloperSharp.RabbitMQ包
--------------------------

            //定義bbq隊列,其中存放的消息會在60秒後過期
            var myQ = RabbitMQHelper.SetQueue("bbq", 60000);

            //定義與bbq隊列對應的死信隊列
            var expQ = RabbitMQHelper.GetQueue("bbq");
            //向BB.txt這個文本文件中連續寫入死信隊列中的消息
            expQ.UseMessage(t =>
            {
                System.IO.File.AppendAllText("D:/BB.txt", t.Message);
                return true;
            });

            //向bbq隊列發送3個消息
            myQ.SendMessage("jinA");
            myQ.SendMessage("jinB");
            myQ.SendMessage("jinC");

運行以上程式:

60秒之內,【BB.txt文件】中沒有內容

60秒以後,【BB.txt文件】中顯示出:jinAjinBjinC

 

通過以上例子,我們可簡單預測一下,延時隊列&死信隊列常用在“限時消費”、“過期處理”等場景。生活中最常見示例如:訂單請在10分鐘內支付完畢、等等之類功能...

 

(其它說明:為了演示便利,文本前面給出的幾個代碼示例中,把SendMessage、GetMessage、UseMessage三個方法都放到了同一段代碼程式中,這樣做不好,偶爾會造成一些資源衝突。在實際使用中,最好是把它們分開分別放到三段不同的代碼程式中,以獲取最佳效果。比如:三個按鈕、三個服務,之類...)

 

使用消息服務對解耦分散式系統、實現發佈/訂閱、提高系統性能、等方面都有巨大用處,相信本文會擴展你的思維認知,讓你在相關技術解決方案上有更多靈活思路+聯想空間!

 


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

-Advertisement-
Play Games
更多相關文章
  • 我們在使用pandas處理完數據之後,最終總是要把數據作為一個文件保存下來,那麼,保存數據最常用的文件是什麼呢?我想大部分人一定會選擇csv或者excel。 剛接觸數據分析時,我也是這麼選擇的,不過,今天將介紹幾種不一樣的存儲數據的文件格式。這些文件格式各有自己的一些優點,希望本文能讓你以後的數據存 ...
  • 前言 想開發一些小工具,所以想系統性的學習一遍aardio,之前都是哪裡不會搜哪裡,順便寫些教程。我的主要語言是Python,所以會以Python作為對比來加深印象。 aardio的基礎語法和JavaScript基本類似,如果你學過JavaScript,aardio很容易上手。下麵的文檔來自官方文檔 ...
  • 源生成器是 C# 9 中引入的一項功能,允許在編譯過程中動態生成代碼。 它們直接與 C# 編譯器集成(Roslyn)併在編譯時運行,分析源代碼並根據分析結果生成附加代碼。 源生成器提供了一種簡化的自動化代碼生成方法,無需外部工具或單獨的預編譯步驟。 通過無縫集成到編譯過程中,源生成器可以提高生產力、 ...
  • 這是一個我個人寫的庫,主要實現的是基於tcpclient的網站外擴網盤的解決方案,可以使用家用網路外掛個人電腦中的資源到自己的網站上,已經上傳nuget,大家可以直接在nuget包管理中搜索到,直接搜索ZmjNetDisk即可,下麵介紹具體的使用方式: 另外一提這個庫做的比較的個人化,因為他就是為了 ...
  • 1. 渲染系統概述 WPF 採用保留模式渲染系統 (Retained Mode Rendering System),該系統可分為 UI 線程和複合線程兩個主要部分,兩者協作完成 WPF 應用程式的渲染工作。 1.1 立即模式GUI和保持模式GUI 圖形 API 可分為保留模式API 和即時模式API ...
  • 在開發各種應用程式時,我們經常需要對文件系統中的文件或文件夾進行實時監測,以便在文件內容改變、文件被創建或刪除時能夠及時做出反應。在 C# 中,System.IO.FileSystemWatcher 類為我們提供了這樣一個強大的功能。 一、引入 FileSystemWatcher 類 首先,在項目中 ...
  • 我個人編寫的庫,在我個人網站,小程式等很多地方都在使用中,大家可以搜索小程式 什邡市宅貓君網路工作室 或者到我的網站 store.zhaimaojun.cn 去體驗支付和登錄效果。 本庫主要實現了native pay(二維碼支付)jsapi pay(小程式直接調起支付),需要註意的是這是基於api3 ...
  • 這是我自己個人編寫的日誌記錄,主要使用在只需要記錄日誌,偶爾到文件中查看一下日誌記錄的情況。我自己寫的一些服務之類的是使用了這個的,代碼很少,使用很簡單。 第一步 搜索和安裝我的Nuget包 搜索和安裝zmjtool這個包,我寫的,如下圖: 第二步 引入namespace和創建logger對象 1 ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...