亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么使用.NETCore操作RabbitMQ

發布時間:2021-05-11 11:50:57 來源:億速云 閱讀:598 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關怎么使用.NETCore操作RabbitMQ,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

什么是RabbitMQ?

怎么使用.NETCore操作RabbitMQ

RabbitMQ是由erlang語言開發的一個基于AMQP(Advanced Message Queuing Protocol)協議的企業級消息隊列中間件。可實現隊列,訂閱/發布,路由,通配符等工作模式。

為什么要使用RabbitMQ?

  • 異步處理:比如發送郵件,發送短信等不需要等待處理結果的操作

  • 應用解耦:比如下單成功后,通知倉庫發貨,不需要等待倉庫回應,通過消息隊列去通知倉庫,降低應用間耦合程序,可并行開發兩個功能模塊

  • 流量削鋒:在搶購或者其他的活動頁,服務處于爆發式請求狀態,如果直連數據庫,數據庫容易被拖垮。搶購商品也容易出現庫存超賣的情況。通過隊列可有效解決該問題。

  • 日志處理:在單機中,日志直接寫入到文件目錄中,但是在分布式應用中,日志需要有統一的處理機制,可通過消息隊列統一由某個消費端做處理。

  • 消息通信:如生產端和消費端可通過隊列進行異步通信

如何安裝RabbitMQ?

Windows端

1.安裝erlang語言運行環境
https://erlang.org/download/otp_win64_23.2.exe
下載后直接下一步即可

2.安裝RabbitMQ
https://www.rabbitmq.com/install-windows.html
直接點擊安裝下一步即可按章

3.安裝RabbitMQ的Web管理平臺

RabbitMQ的管理平臺是通過插件的形式使用,需要手動啟用管理平臺
在Windows下,RabbitMQ默認被安裝到C:\Program Files\RabbitMQ Server\rabbitmq_server-3.8.14 下。
打開sbin ,在cmd或者powershell中執行

rabbitmq-plugins.bat enable rabbitmq_management

安裝完成后,瀏覽器打開 http://localhost:15672/ 即可看到RabbitMQ的管理界面。輸入默認賬號密碼 guest 成功登錄。

Linux環境安裝

1.Ubuntu:https://www.rabbitmq.com/install-debian.html

2.Centos:https://www.rabbitmq.com/install-rpm.html

RabbitMQ的基本概念

生產者

發送消息的端

消費者

獲取消息并處理的端

Connection

一個終端連接。每一個Connection都可以在RabbitMQ后臺看到

怎么使用.NETCore操作RabbitMQ

Channel

Channel是建立在Connection上的一個虛擬通信管道。一般情況下,往消息隊列中寫入多條消息,為了不每條消息都建立一個TCP連接,所以RabbitMQ的做法是多條消息可以公用一個Connection,大大提高MQ的負載能力。

Exchange

Exchange是一個虛擬交換機。每一條消息都必須要通過交換機才能能進入對應的隊列,可以理解為網絡設備中的交換機,是一個意思。

Queue

Queue是一個存儲消息的內部對象,所有的Rabbit MQ消息都存儲在Queue中。生產者所生產的消息會存儲在Queue中,消費者獲取的消息也是從Queue中獲取。

如何在.NET Core中使用RabbitMQ?

nuget安裝

dotnet add package RabbitMQ.Client

創建生產者

const string QUEUENAME = "HELLO_MQ";
//創建連接對象工廠
var factory = new ConnectionFactory()
{
    UserName = "guest",
    Password = "guest",
    HostName = "localhost",
    Port = 5672,  //RabbitMQ默認的端口
};

while (true)
{
    using var conn = factory.CreateConnection();
    var chanel = conn.CreateModel();

    chanel.QueueDeclare(QUEUENAME, true, false, false);
    Console.WriteLine("輸入生產內容:");
    var input = Console.ReadLine();
    chanel.BasicPublish("", QUEUENAME, null, Encoding.Default.GetBytes("hello rabbitmq:" + input));
}

在循環中,輸入一個值,按下enter,即可推送一條消息到隊列。

也可以直接在RabbitMQ的管理后臺查看

怎么使用.NETCore操作RabbitMQ

怎么使用.NETCore操作RabbitMQ

怎么使用.NETCore操作RabbitMQ

可以看到我們發送的消息已經被RabbitMQ存儲在Queue中了。只等某個幸運的消費者前來消費。

創建消費者

const string QUEUENAME = "HELLO_MQ";
var factory = new ConnectionFactory()
{
    UserName = "guest",
    Password = "guest",
    HostName = "localhost",
    Port = 5672,
};

var conn = factory.CreateConnection();
var chanel = conn.CreateModel();
chanel.QueueDeclare(QUEUENAME, true, false, false);
EventingBasicConsumer consumer = new EventingBasicConsumer(chanel);
consumer.Received += (a, e) =>
{
    Console.WriteLine($"{DateTime.Now.ToString()}接收到消息:" + Encoding.Default.GetString(e.Body.ToArray()));
    chanel.BasicAck(e.DeliveryTag, true); //收到回復后,RabbitMQ會直接在隊列中刪除這條消息
};
chanel.BasicConsume(QUEUENAME, false, consumer);

Console.WriteLine("啟動成功");
Console.ReadLine();

啟動成功后,consumer的Received方法,會收到一條來自MQ的消息,

怎么使用.NETCore操作RabbitMQ

如果處理完成后,不調用chennel的BasicAck方法,那么這條消息依然會存在,下次有消費者出現,會再次推送給消費者。

簡單的RabbitMQ Hello World到這里就算完成了。接下來就是稍微高級一點的應用

RabbitMQ的工作模式

Work Queue 工作隊列模式

怎么使用.NETCore操作RabbitMQ

工作隊列模式的意思就是一個生產者對應多個消費者。RabbitMQ會使用輪詢去給每個消費者發送消息。

publish/subscribe

發布訂閱模式是屬于比較用多的一種。

怎么使用.NETCore操作RabbitMQ

發布訂閱,是由交換機發布消息給多個隊列。多個隊列再對應多個消費者。

發布訂閱模式對應的交換機類型的fanout。

消費者

A

const string QUEUENAME = "HELLO_MQ_B";
const string TESTEXCHANGE = "TESTEXCHANGE";
var factory = new ConnectionFactory()
{
    UserName = "guest",
    Password = "guest",
    HostName = "localhost",
    Port = 5672,
};

var conn = factory.CreateConnection();
var channel = conn.CreateModel();
//定義隊列
channel.QueueDeclare(QUEUENAME, true, false, false);
//定義交換機
channel.ExchangeDeclare(TESTEXCHANGE, ExchangeType.Fanout, true, false);
//綁定隊列到交換機
channel.QueueBind(QUEUENAME, TESTEXCHANGE, "");
var consumer = new EventingBasicConsumer(channel);
consumer.Received += (a, e) =>
{
    Console.WriteLine($"{DateTime.Now.ToString()}接收到消息:" + Encoding.Default.GetString(e.Body.ToArray()));
    channel.BasicAck(e.DeliveryTag, true); //收到回復后,RabbitMQ會直接在隊列中刪除這條消息
};
channel.BasicConsume(QUEUENAME, false, consumer);

Console.WriteLine("啟動成功");
Console.ReadLine();

B

const string QUEUENAME = "HELLO_MQ";
const string TESTEXCHANGE = "TESTEXCHANGE";
var factory = new ConnectionFactory()
{
    UserName = "guest",
    Password = "guest",
    HostName = "localhost",
    Port = 5672,
};

var conn = factory.CreateConnection();
var channel = conn.CreateModel();
//定義隊列
channel.QueueDeclare(QUEUENAME, true, false, false);
//定義交換機
channel.ExchangeDeclare(TESTEXCHANGE, ExchangeType.Fanout, true, false);
//綁定隊列到交換機
channel.QueueBind(QUEUENAME, TESTEXCHANGE, "");
var consumer = new EventingBasicConsumer(channel);
consumer.Received += (a, e) =>
{
    Console.WriteLine($"{DateTime.Now.ToString()}接收到消息:" + Encoding.Default.GetString(e.Body.ToArray()));
    channel.BasicAck(e.DeliveryTag, true); //收到回復后,RabbitMQ會直接在隊列中刪除這條消息
};
channel.BasicConsume(QUEUENAME, false, consumer);

Console.WriteLine("啟動成功");
Console.ReadLine();

生產者

const string QUEUENAME = "HELLO_MQ";
const string QUEUENAME_B = "HELLO_MQ_B";
const string TESTEXCHANGE = "TESTEXCHANGE";

//創建連接對象工廠
var factory = new ConnectionFactory()
{
    UserName = "guest",
    Password = "guest",
    HostName = "localhost",
    Port = 5672,  //RabbitMQ默認的端口
};
using var conn = factory.CreateConnection();
while (true)
{

    var channel = conn.CreateModel();
    //定義交換機
    channel.ExchangeDeclare(TESTEXCHANGE, ExchangeType.Fanout, true, false);
    Console.WriteLine("輸入生產內容:");
    var input = Console.ReadLine();
    channel.BasicPublish(TESTEXCHANGE,"", null, Encoding.Default.GetBytes("hello rabbitmq:" + input));
}

在生產者運行成功后,RabbitMQ后臺會出現一個交換機,點擊交換機會看到交換機下綁定了兩個隊列

怎么使用.NETCore操作RabbitMQ

怎么使用.NETCore操作RabbitMQ

從生產者發送消息到隊列,兩個消費者會同時收到消息

怎么使用.NETCore操作RabbitMQ

routing模式

怎么使用.NETCore操作RabbitMQ

routing模式對應的交換機類型是direct,和發布訂閱模式的區別在于:routing模式下,可以指定一個routingkey,用于區分消息

生產者

var channel = conn.CreateModel();
//定義交換機
channel.ExchangeDeclare(TESTEXCHANGE, ExchangeType.Direct, true, false);
//綁定隊列到交換機
Console.WriteLine("輸入生產內容:");
var input = Console.ReadLine();
channel.BasicPublish(TESTEXCHANGE, "INFO", null, Encoding.Default.GetBytes("hello rabbitmq:" + input));

消費者 A

//定義隊列
channel.QueueDeclare(QUEUENAME, true, false, false);
//定義交換機
channel.ExchangeDeclare(TESTEXCHANGE, ExchangeType.Direct, true, false);
//綁定隊列到交換機
channel.QueueBind(QUEUENAME, TESTEXCHANGE, "INFO");

消費者 B

//定義隊列
channel.QueueDeclare(QUEUENAME, true, false, false);
//定義交換機
channel.ExchangeDeclare(TESTEXCHANGE, ExchangeType.Direct, true, false);
//綁定隊列到交換機
channel.QueueBind(QUEUENAME, TESTEXCHANGE, "ERROR");

綁定成功后,發送消息,消費者A可以收到消息,消費者B無法收到消息。

如果遇到指定routingKey生產一條消息,結果 AB消費者都收到的情況。建議在RabbitMQ后臺的交換機下看一下綁定的Queue是否重復綁定了多個routingKey.

怎么使用.NETCore操作RabbitMQ

topic通配符模式

怎么使用.NETCore操作RabbitMQ

在通配符模式下,RabbitMQ使用模糊匹配來決定把消息推送給哪個生產者。通配符有兩個符號來匹配routingKey

1.*匹配一個字符 如:*.qq.com 可匹配 1.qq.com

2.#匹配一個或者多個字符。 如:*.qq.com 可匹配 1.qq.com或者1111.qq.com

其他的操作基本和routing模式一樣。

header模式

header模式是把routingkey放到header中.取消掉了routingKey。并使用一個字典傳遞 K、V的方式來匹配。
比如同時要給用戶發送郵件和短信,可直接通過header的鍵值對來匹配綁定的值,把消息傳遞給發短信和郵件的生產者.

關于“怎么使用.NETCore操作RabbitMQ”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

无锡市| 富宁县| 蒲江县| 嘉峪关市| 积石山| 建德市| 施秉县| 富顺县| 黄山市| 呼玛县| 柞水县| 高唐县| 白沙| 全南县| 宣武区| 潼南县| 中阳县| 龙门县| 伽师县| 龙泉市| 双峰县| 湟源县| 日土县| 兴隆县| 徐州市| 怀柔区| 瓮安县| 凤冈县| 鹤峰县| 平昌县| 黄平县| 金溪县| 唐山市| 会泽县| 汾西县| 钦州市| 北票市| 嘉黎县| 嘉荫县| 揭东县| 东辽县|