成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在.NET中集成RabbitMQ實現(xiàn)消息列隊功能,實例解析

開發(fā) 架構(gòu)
使用 RabbitMQ 是一種常見的消息隊列解決方案,用于構(gòu)建可擴展的分布式應(yīng)用程序。下面我將詳細(xì)講解如何在 .NET 中使用 RabbitMQ,包括常用功能和示例源代碼。

1、安裝 RabbitMQ

首先,你需要安裝 RabbitMQ 服務(wù)器。你可以從官方網(wǎng)站下載 RabbitMQ,并按照官方文檔進行安裝和配置。安裝完成后,確保 RabbitMQ 服務(wù)器正在運行。

2、使用 RabbitMQ 基本功能

(1)發(fā)布和訂閱消息

RabbitMQ 的基本工作方式是生產(chǎn)者將消息發(fā)布到交換機,然后由消費者從隊列中訂閱消息。以下是一個示例:

// 生產(chǎn)者
var factory = new ConnectionFactory() { HostName = "localhost" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
    channel.ExchangeDeclare(exchange: "logs", type: ExchangeType.Fanout);
    var message = "Hello, RabbitMQ!";
    var body = Encoding.UTF8.GetBytes(message);
    channel.BasicPublish(exchange: "logs", routingKey: "", basicProperties: null, body: body);
    Console.WriteLine("Sent: {0}", message);
}

// 消費者
var factory = new ConnectionFactory() { HostName = "localhost" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
    channel.ExchangeDeclare(exchange: "logs", type: ExchangeType.Fanout);
    var queueName = channel.QueueDeclare().QueueName;
    channel.QueueBind(queue: queueName, exchange: "logs", routingKey: "");
    
    var consumer = new EventingBasicConsumer(channel);
    consumer.Received += (model, ea) =>
    {
        var body = ea.Body.ToArray();
        var message = Encoding.UTF8.GetString(body);
        Console.WriteLine("Received: {0}", message);
    };
    channel.BasicConsume(queue: queueName, autoAck: true, consumer: consumer);
}

上述代碼中,生產(chǎn)者將消息發(fā)布到名為 "logs" 的交換機,而消費者從該交換機創(chuàng)建一個隊列并訂閱消息。

(2)路由消息

RabbitMQ 允許你使用路由鍵將消息路由到特定隊列。以下是一個示例:

// 生產(chǎn)者
var factory = new ConnectionFactory() { HostName = "localhost" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
    channel.ExchangeDeclare(exchange: "direct_logs", type: ExchangeType.Direct);
    var severity = "info";
    var message = "Informational message.";
    var body = Encoding.UTF8.GetBytes(message);
    channel.BasicPublish(exchange: "direct_logs", routingKey: severity, basicProperties: null, body: body);
    Console.WriteLine("Sent: [{0}] {1}", severity, message);
}

// 消費者
var factory = new ConnectionFactory() { HostName = "localhost" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
    channel.ExchangeDeclare(exchange: "direct_logs", type: ExchangeType.Direct);
    var queueName = channel.QueueDeclare().QueueName;
    var severity = "info";
    channel.QueueBind(queue: queueName, exchange: "direct_logs", routingKey: severity);

    var consumer = new EventingBasicConsumer(channel);
    consumer.Received += (model, ea) =>
    {
        var body = ea.Body.ToArray();
        var message = Encoding.UTF8.GetString(body);
        Console.WriteLine("Received: [{0}] {1}", severity, message);
    };
    channel.BasicConsume(queue: queueName, autoAck: true, consumer: consumer);
}

在此示例中,消息被路由到具有特定路由鍵 "info" 的隊列。

(3)主題交換機

RabbitMQ 還支持主題交換機,允許你根據(jù)模式匹配消息的路由鍵進行訂閱。以下是一個示例:

// 生產(chǎn)者
var factory = new ConnectionFactory() { HostName = "localhost" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
    channel.ExchangeDeclare(exchange: "topic_logs", type: ExchangeType.Topic);
    var routingKey = "kern.critical";
    var message = "Critical kernel error.";
    var body = Encoding.UTF8.GetBytes(message);
    channel.BasicPublish(exchange: "topic_logs", routingKey: routingKey, basicProperties: null, body: body);
    Console.WriteLine("Sent: [{0}] {1}", routingKey, message);
}

// 消費者
var factory = new ConnectionFactory() { HostName = "localhost" };
using (var connection = factory.CreateConnection())
using (var channel = connection.CreateModel())
{
    channel.ExchangeDeclare(exchange: "topic_logs", type: ExchangeType.Topic);
    var queueName = channel.QueueDeclare().QueueName;
    var routingKey = "kern.*";
    channel.QueueBind(queue: queueName, exchange

: "topic_logs", routingKey: routingKey);

    var consumer = new EventingBasicConsumer(channel);
    consumer.Received += (model, ea) =>
    {
        var body = ea.Body.ToArray();
        var message = Encoding.UTF8.GetString(body);
        Console.WriteLine("Received: [{0}] {1}", routingKey, message);
    };
    channel.BasicConsume(queue: queueName, autoAck: true, consumer: consumer);
}

在此示例中,消息被路由到匹配模式 "kern.*" 的隊列。

3、其他功能

RabbitMQ 還支持消息持久化、RPC(遠程過程調(diào)用)、集群和安全等功能。你可以根據(jù)項目需求探索這些功能,并使用RabbitMQ的官方文檔和.NET客戶端庫來實現(xiàn)。

上述示例涵蓋了RabbitMQ的一些常見用例,希望可以幫助你入門RabbitMQ并在.NET應(yīng)用程序中使用它。

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2009-06-01 16:18:30

SpringJPA集成

2024-05-16 08:10:17

RabbitMQ軟件通信機制

2024-06-24 08:42:11

2009-06-23 09:33:20

FCKEditorJSFJSP

2011-07-20 17:10:05

iPhone iAd

2021-11-01 14:52:38

ElasticSear索引SQL

2009-01-03 15:01:16

ibmdwLptus

2009-01-03 14:43:55

ibmdwPHPsMash

2014-09-28 14:53:39

滲透BurpSuiteSqlmap

2011-06-29 09:42:12

Visual Stud Qt Opensource

2011-08-23 09:50:29

LuaPlusLua 腳本

2016-04-20 09:47:40

MapBoxAndroid地圖

2009-06-11 13:28:18

Glassfish集成

2021-09-16 10:29:05

開發(fā)技能代碼

2024-09-30 09:48:41

RabbitMQ消息中間件

2022-08-02 11:27:25

RabbitMQ消息路由

2025-05-29 01:33:00

微服務(wù)架構(gòu)系統(tǒng)

2012-10-18 10:12:42

IBMdw

2009-09-03 16:27:57

ASP.NET回車事件

2011-03-04 09:40:42

AJAX開發(fā)集成數(shù)據(jù)庫
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲视频在线看 | 国产精品美女久久久久久久久久久 | 麻豆久久久久久久久久 | 中文成人无字幕乱码精品 | 超碰在线免费av | 人人澡视频 | 成人性生交大片免费看r链接 | 最近中文字幕在线视频1 | 91久久精品国产 | 日韩淫片免费看 | 曰批视频在线观看 | 久久九九99 | 91国在线高清视频 | 亚洲精品一 | 免费国产一区二区 | 亚洲一区二区三区四区五区午夜 | 手机av在线 | 色婷婷综合在线观看 | 精品一区二区三区视频在线观看 | 成人二区三区 | 欧美激情久久久 | 欧美激情国产日韩精品一区18 | 久久久精品日本 | 夫妻午夜影院 | 国产电影一区二区 | 亚洲传媒在线 | 久久国产一区二区三区 | 99九色| 综合激情av | 成人 在线 | 中文字幕在线看第二 | 91在线免费视频 | 秋霞a级毛片在线看 | 日韩国产三区 | 精品欧美一区二区中文字幕视频 | 日韩亚洲视频 | 99久久99| 欧美日韩国产精品一区 | 99综合 | 黄色一级视频 | 国内精品久久久久久影视8 最新黄色在线观看 |