asp.net core rabbitmq的基本使用

要在 .NET Core 应用程序中实现使用 RabbitMQ 发送和接收消息的简单示例,首先需要在开发机器上安装 RabbitMQ 服务器并运行它。接下来,我们将创建两个控制台应用程序:一个用于发送消息(生产者),另一个用于接收消息(消费者)。

步骤 1: 安装 RabbitMQ 客户端库

  1. 创建两个控制台项目(例如,RabbitMQProducerRabbitMQConsumer)。

  2. 在每个项目中,使用 NuGet 安装 RabbitMQ 客户端库。打开项目的 NuGet 包管理器控制台(PMC),并运行以下命令:

    bash 复制代码
    Install-Package RabbitMQ.Client -Version 6.2.1

    根据您看到的最新版本进行调整。

步骤 2: 实现生产者

RabbitMQProducer 项目的 Program.cs 中,添加以下代码来实现一个简单的消息生产者:

csharp 复制代码
using System;
using RabbitMQ.Client;
using System.Text;

class Program
{
    static void Main(string[] args)
    {
        // 连接到 RabbitMQ 服务器
        var factory = new ConnectionFactory() { HostName = "localhost" };
        using(var connection = factory.CreateConnection())
        using(var channel = connection.CreateModel())
        {
            // 声明一个队列
            channel.QueueDeclare(queue: "hello",
                                 durable: false,
                                 exclusive: false,
                                 autoDelete: false,
                                 arguments: null);

            string message = "Hello World!";
            var body = Encoding.UTF8.GetBytes(message);

            // 发送消息到队列
            channel.BasicPublish(exchange: "",
                                 routingKey: "hello",
                                 basicProperties: null,
                                 body: body);
            Console.WriteLine(" [x] Sent {0}", message);
        }
        
        Console.WriteLine(" Press [enter] to exit.");
        Console.ReadLine();
    }
}

步骤 3: 实现消费者

RabbitMQConsumer 项目的 Program.cs 中,添加以下代码来实现一个简单的消息消费者:

csharp 复制代码
using RabbitMQ.Client;
using RabbitMQ.Client.Events;
using System;
using System.Text;

class Program
{
    static void Main(string[] args)
    {
        // 连接到 RabbitMQ 服务器
        var factory = new ConnectionFactory() { HostName = "localhost" };
        using (var connection = factory.CreateConnection())
        using (var channel = connection.CreateModel())
        {
            // 声明一个队列
            channel.QueueDeclare(queue: "hello",
                                 durable: false,
                                 exclusive: false,
                                 autoDelete: false,
                                 arguments: null);

            var consumer = new EventingBasicConsumer(channel);
            consumer.Received += (model, ea) =>
            {
                var body = ea.Body.ToArray();
                var message = Encoding.UTF8.GetString(body);
                Console.WriteLine(" [x] Received {0}", message);
            };
            // 开始消费队列中的消息
            channel.BasicConsume(queue: "hello",
                                 autoAck: true,
                                 consumer: consumer);

            Console.WriteLine(" Press [enter] to exit.");
            Console.ReadLine();
        }
    }
}

步骤 4: 运行示例

  1. 确保 RabbitMQ 服务在本地运行。
  2. 首先启动 RabbitMQConsumer 程序以确保它正在等待接收消息。
  3. 然后启动 RabbitMQProducer 程序发送消息。

如果一切设置正确,您将在 RabbitMQConsumer 控制台应用程序中看到收到的消息 "Hello World!"。

这个简单的示例展示了如何在 .NET Core 中使用 RabbitMQ 实现基本的消息发布和订阅。在实际应用中,您可能还需要考虑消息确认、错误处理和重试机制,以构建更健壮和可靠的消息系统。

相关推荐
苦学编程的谢4 小时前
RabbitMQ_6_高级特性(3)
分布式·rabbitmq
梁正雄4 小时前
linux服务-RabbitMQ 原理与安装
linux·rabbitmq·ruby
醉风塘1 天前
RabbitMQ状态与配置深度解读:构建高性能消息中间件的关键指标
分布式·rabbitmq
添加shujuqudong1如果未回复1 天前
无刷直流电机BLDC转速电流双闭环调速系统Matlab Simulink仿真
rabbitmq
better_liang1 天前
每日Java面试场景题知识点之-RabbitMQ
java·消息队列·rabbitmq·面试题·异步通信·企业级开发·系统解耦
jiayong232 天前
微服务架构与 Spring 生态完全指南
kafka·rabbitmq·rocketmq
哇哈哈&2 天前
如何进行卸载rabbitmq
分布式·rabbitmq
华仔啊3 天前
RabbitMQ 如何保证消息不丢失和不重复消费?掌握这 4 个关键点就够了
java·后端·rabbitmq
jiayong233 天前
RabbitMQ 完全指南
分布式·rabbitmq
luod3 天前
RabbitMQ工作队列模式理解
rabbitmq