当前位置: 首页 > article >正文

在一个.NET Core项目中使用RabbitMQ进行即时消息管理

为了在一个.NET Core项目中使用RabbitMQ进行即时消息管理,以下是详细的全程操作指南,包括安装、配置、编写代码和调试使用。
在这里插入图片描述

一、安装RabbitMQ

1. 安装Erlang

RabbitMQ依赖Erlang,因此需要先安装Erlang。

  • Windows:
    下载并运行Erlang安装程序:Erlang下载页面
2. 安装RabbitMQ
  • Windows:
    下载并运行RabbitMQ安装程序:RabbitMQ下载页面

二、配置RabbitMQ

1. 启用管理插件

打开命令提示符,并运行以下命令:

rabbitmq-plugins enable rabbitmq_management
2. 创建用户并设置权限
rabbitmqctl add_user myuser mypassword
rabbitmqctl set_permissions -p / myuser ".*" ".*" ".*"
rabbitmqctl set_user_tags myuser administrator
3. 访问管理界面

在浏览器中访问:http://localhost:15672
使用刚才创建的用户名 myuser 和密码 mypassword 登录。

三、在.NET Core项目中使用RabbitMQ

在这里插入图片描述

1. 创建.NET Core项目

打开命令提示符或PowerShell,进入你想创建项目的目录,然后运行以下命令:

dotnet new console -n IMProject
cd IMProject

在这里插入图片描述

2. 安装RabbitMQ.Client包

在项目目录中运行以下命令安装RabbitMQ的客户端库:

dotnet add package RabbitMQ.Client
3. 编写发送和接收消息的代码
发送消息 (Producer)

创建一个文件 Producer.cs,内容如下:

using System;
using RabbitMQ.Client;
using System.Text;

class Producer
{
    public static void Main()
    {
        var factory = new ConnectionFactory() { HostName = "localhost" };
        using (var connection = factory.CreateConnection())
        using (var channel = connection.CreateModel())
        {
            channel.QueueDeclare(queue: "chat",
                                 durable: false,
                                 exclusive: false,
                                 autoDelete: false,
                                 arguments: null);

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

            channel.BasicPublish(exchange: "",
                                 routingKey: "chat",
                                 basicProperties: null,
                                 body: body);
            Console.WriteLine(" [x] Sent {0}", message);
        }
    }
}
接收消息 (Consumer)

创建一个文件 Consumer.cs,内容如下:

using System;
using RabbitMQ.Client;
using RabbitMQ.Client.Events;
using System.Text;

class Consumer
{
    public static void Main()
    {
        var factory = new ConnectionFactory() { HostName = "localhost" };
        using (var connection = factory.CreateConnection())
        using (var channel = connection.CreateModel())
        {
            channel.QueueDeclare(queue: "chat",
                                 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: "chat",
                                 autoAck: true,
                                 consumer: consumer);

            Console.WriteLine(" [*] Waiting for messages. To exit press CTRL+C");
            Console.ReadLine();
        }
    }
}

四、调试和运行

在这里插入图片描述

1. 运行接收消息的程序

在命令提示符或PowerShell中,运行以下命令:

dotnet run --project ./Consumer.csproj

你应该会看到类似以下的输出:

 [*] Waiting for messages. To exit press CTRL+C
2. 运行发送消息的程序

打开另一个命令提示符或PowerShell窗口,运行以下命令:

dotnet run --project ./Producer.csproj

你应该会看到类似以下的输出:

 [x] Sent Hello World!

在接收消息的程序窗口中,你应该会看到类似以下的输出:

 [x] Received Hello World!

五、集成到IM项目中

为了将RabbitMQ集成到一个更复杂的IM项目中,你可以创建一个ASP.NET Core Web API项目,并在控制器中使用RabbitMQ来发送和接收消息。

1. 创建ASP.NET Core Web API项目

在命令提示符或PowerShell中,运行以下命令:

dotnet new webapi -n IMWebApi
cd IMWebApi
2. 安装RabbitMQ.Client包

在项目目录中运行以下命令安装RabbitMQ的客户端库:

dotnet add package RabbitMQ.Client
3. 创建消息服务

创建一个文件 Services/RabbitMQService.cs,内容如下:

using RabbitMQ.Client;
using RabbitMQ.Client.Events;
using System;
using System.Text;

public class RabbitMQService
{
    private readonly ConnectionFactory _factory;

    public RabbitMQService()
    {
        _factory = new ConnectionFactory() { HostName = "localhost" };
    }

    public void SendMessage(string message)
    {
        using (var connection = _factory.CreateConnection())
        using (var channel = connection.CreateModel())
        {
            channel.QueueDeclare(queue: "chat",
                                 durable: false,
                                 exclusive: false,
                                 autoDelete: false,
                                 arguments: null);

            var body = Encoding.UTF8.GetBytes(message);

            channel.BasicPublish(exchange: "",
                                 routingKey: "chat",
                                 basicProperties: null,
                                 body: body);
            Console.WriteLine(" [x] Sent {0}", message);
        }
    }

    public void ReceiveMessages()
    {
        using (var connection = _factory.CreateConnection())
        using (var channel = connection.CreateModel())
        {
            channel.QueueDeclare(queue: "chat",
                                 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: "chat",
                                 autoAck: true,
                                 consumer: consumer);

            Console.WriteLine(" [*] Waiting for messages. To exit press CTRL+C");
            Console.ReadLine();
        }
    }
}
4. 创建控制器

创建一个文件 Controllers/ChatController.cs,内容如下:

using Microsoft.AspNetCore.Mvc;

[ApiController]
[Route("[controller]")]
public class ChatController : ControllerBase
{
    private readonly RabbitMQService _rabbitMQService;

    public ChatController()
    {
        _rabbitMQService = new RabbitMQService();
    }

    [HttpPost("send")]
    public IActionResult SendMessage([FromBody] string message)
    {
        _rabbitMQService.SendMessage(message);
        return Ok("Message sent");
    }

    [HttpGet("receive")]
    public IActionResult ReceiveMessages()
    {
        _rabbitMQService.ReceiveMessages();
        return Ok("Receiving messages");
    }
}
5. 运行Web API

在命令提示符或PowerShell中,运行以下命令:

dotnet run

你可以使用Postman或其他API测试工具来发送和接收消息:

  • 发送消息:POST http://localhost:5000/chat/send,请求体为纯文本消息。
  • 接收消息:GET http://localhost:5000/chat/receive

六、调试和测试

在这里插入图片描述

1. 发送消息

使用Postman发送一个POST请求到http://localhost:5000/chat/send,请求体为纯文本消息,例如:“Hello from Postman”。

2. 接收消息

在浏览器或Postman中发送一个GET请求到http://localhost:5000/chat/receive,你应该会在控制台中看到接收到的消息。

七、总结

通过以上步骤,你已经成功地在一个.NET Core项目中使用RabbitMQ进行即时消息管理。你可以根据项目的需求进一步扩展和优化。例如,使用依赖注入来管理RabbitMQService,处理消息的持久化存储,添加更多的业务逻辑等。

//python 因为爱,所以学
print("Hello, Python!")

关注我,不迷路,共学习,同进步

关注我,不迷路,共学习,同进步


http://www.kler.cn/news/324115.html

相关文章:

  • 前端注释规范
  • Mac安装manim
  • R包:VennDiagram韦恩图
  • 1.2.3 HuggingFists安装说明-MacOS安装
  • 供应链 | 顶刊POMS论文精读:交易成本经济学(TCE)——供应链效率理论
  • 小白投资理财 - 证券开户
  • WPF MVVM入门系列教程(一、MVVM模式介绍)
  • React 有哪些生命周期
  • 开源服务器管理软件Nexterm
  • 提取出来的ip与我原本的ip是在同一个区吗
  • Python编码系列—Python备忘录模式:掌握对象状态保存与恢复技术
  • 【成神之路】Ambari实战-013-代码生命周期-metainfo-configFiles详解
  • 【Linux】包管理器、vim详解及简单配置
  • 实战C++手写线程池
  • windows11下vscode配置lua环境
  • 1欧几里得聚类提取
  • WPF入门教学二十二 多线程与异步编程
  • Django——admin创建和使用
  • 【Python游戏开发】扫雷游戏demo
  • Linux云计算 |【第四阶段】RDBMS1-DAY2
  • 使用python获取百度一下,热搜TOP数据详情
  • 什么是聚类?
  • Docker数据卷有哪些常见的驱动类型?
  • K8S真正删除pod
  • SeeClick: Harnessing GUI Grounding for Advanced Visual GUI Agents论文学习
  • socket编程描述tcp的三次握手
  • Postman/Jmeter接口测试
  • MATLAB中的并行计算:提升性能的策略与实践
  • 有关若依菜单管理的改造
  • 动手学深度学习(李沐)PyTorch 第 4 章 多层感知机