ASP.NET CORE 6.0实现MassTransit

目录

1. 安装必要的 NuGet 包

2. 配置 MassTransit、注册消费者

3. 定义消息和消费者

4. 发送消息

MassTransit 是一个轻量级的 .NET 消息总线(message bus)框架,它支持多种消息队列中间件,如 RabbitMQ、Azure Service Bus、ActiveMQ 等。它允许开发人员轻松实现分布式应用程序的消息传递和处理。

前提条件:RabbitMQ需要安装
参考安装教程:RabbitMQ在Windows下的安装过程解决安装 RabbitMQ 安装不成功的问题

要在 .NET 6.0 Web API 中使用 MassTransit,你可以按照以下步骤进行:

1. 安装必要的 NuGet 包

首先,你需要安装 MassTransit 及其支持的消息队列中间件的 NuGet 包 MassTransit.RabbitMQ

2. 配置 MassTransit、注册消费者

Program.cs 文件中配置 MassTransit:

builder.Services.AddMassTransit(x =>
{
    // 添加接收者
    x.AddConsumer<MessageConsumer>();

    x.UsingRabbitMq((context, cfg) =>
    {
        // RabbitMQ服务器的本地地址进行连接
        cfg.Host("rabbitmq://localhost", h =>
        {
            h.Username("guest");
            h.Password("guest");
        });

        // 配置接收者队列
        cfg.ReceiveEndpoint("test-queue", e =>
        {
            e.ConfigureConsumer<MessageConsumer>(context);
        });
    });
});

3. 定义消息和消费者

定义一个消息类:

    /// <summary>
    /// 消费类
    /// </summary>
    public class TestMessage
    {
        public string Text { get; set; }
    }

定义一个消费者:

Consume 方法的作用

  • 处理消息Consume 方法的主要作用是处理接收到的消息。你可以在这个方法中编写业务逻辑来处理消息,例如保存到数据库、调用其他服务、进行计算等。
  • 访问消息上下文:通过 ConsumeContext 对象,你可以访问消息的各种元数据,例如消息头、消息ID、重试次数等,这些信息在处理消息时可能是有用的。
    /// <summary>
    /// MessageConsumer 类是一个消费者,用于处理 TestMessage 类型的消息。
    /// </summary>
    public class MessageConsumer : IConsumer<TestMessage>
    {
        private readonly ILogger<MessageConsumer> _logger;
        /// <summary>
        /// 构造函数,用于注入依赖项。
        /// </summary>
        public MessageConsumer(ILogger<MessageConsumer> logger)
        {
            this._logger = logger;
        }

        /// <summary>
        /// 用于处理接收到的消息。
        /// </summary>
        /// <param name="context"></param>
        /// <returns></returns>
        public async Task Consume(ConsumeContext<TestMessage> context)
        {
            // 记录日志,传入一个上下文对象 context 和格式字符串 "Received message: {Text}",
            // 这里的 {Text} 是 TestMessage 类中的属性。
            _logger.LogInformation("Received message: {Text}", context.Message.Text);

            // 处理消息,这里可以添加具体的处理逻辑。
            // 在这个示例中,我们简单地返回一个已完成的任务。
            await Task.CompletedTask;
        }
    }

4. 发送消息

你可以在你的控制器中发送消息:

    /// <summary>
    /// 这是一个用于处理消息队列的控制器类。
    /// </summary>
    [ApiController]
    [Route("[controller]")]
    public class QueueController : ControllerBase
    {
        private readonly IBus _bus;

        /// <summary>
        /// 构造函数,传入IBus类型的参数bus,将bus赋值给_bus public
        /// </summary>
        /// <param name="bus"></param>
        public QueueController(IBus bus)
        {
            _bus = bus;
        }

        /// <summary>
        /// 发送消息到消息队列
        /// </summary>
        /// <param name="message"></param>
        /// <returns></returns>
        [HttpPost]
        public async Task<IActionResult> SendMessage([FromBody] TestMessage message)
        {
            // 如果message为空或者message的Text属性为空,则返回一个BadRequest响应,响应的内容为"Invalid message."
            if (message == null || string.IsNullOrWhiteSpace(message.Text))
            {
                return BadRequest("Invalid message.");
            }

            // 否则,将message发布到消息总线_bus中
            await _bus.Publish(message);

            return Ok("Message sent.");
        }
    }

发送消息之后会在RabbitMQ队列里面可以看到接收队列的名称“test-queue

以上步骤介绍了如何在 .NET 6.0 Web API 中配置和使用 MassTransit 进行消息传递。你可以根据具体需求选择不同的消息队列中间件并进行相应的配置。

在消息队列系统中,如果两个消费者订阅了同一个队列(如 “test-queue”),那么消息通常只会被其中一个消费者处理。这是因为消息队列通常使用工作队列模式,其中消息在多个消费者之间进行负载均衡,每个消息只被一个消费者处理一次。

具体来说,当你在第一个服务器上发送 SendMessage,消息会进入 test-queue 队列中。MassTransit 和消息队列中间件(如 RabbitMQ)会从队列中取出消息并将其分发给一个可用的消费者。如果第一个服务器的消费者已经取出并处理了消息,第二个服务器的消费者将不会处理同一条消息。

这是消息队列的典型工作方式,用于实现消息处理的负载均衡。

5. 使用场景

示例场景1:

假设你有一个用户注册系统,当用户成功注册后,你希望发送一封欢迎邮件。使用消息队列可以将发送邮件的任务异步处理,从而提高用户注册流程的响应速度。

示例场景2:

假设有一个电商网站,在用户提交订单后,需要进行以下处理:

  1. 验证订单信息。
  2. 检查库存。
  3. 处理支付。
  4. 生成订单确认。

在传统的同步处理方式中,如果某一步骤耗时过长,整个系统的响应时间都会增加。而通过使用消息队列,可以将这些步骤拆分为独立的任务,每个任务由不同的消费者处理:

  1. 用户提交订单后,订单信息被发送到消息队列。
  2. 验证订单的消费者从队列中读取订单信息,进行验证后,将结果发送到下一个队列。
  3. 检查库存的消费者从新队列中读取信息,进行库存检查后,将结果发送到支付队列。
  4. 支付和订单生成步骤依次进行。

这种方式不仅提高了系统的响应速度,还可以通过增加消费者的数量来实现负载均衡。当订单量增加时,可以动态增加消费者数量来处理更多的订单请求,从而实现系统的扩展性和高可用性。

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值