SpringBoot整合Rabbitmq之延时队列

1. 延时队列

1.1. 概念

延时队列是存储延时消息的队列,延时消息就是生产者发送了一条消息,但是不希望该消息不要被立即消费,而是设置一个延时时间,等过了这个时间再消费消息

1.2. 使用场景

  • 订单在十分钟之内未支付则自动取消
  • 新创建的店铺,如果在十天内都没有上传过商品,则自动发送消息提醒
  • 账单在一周内未支付,则自动结算
  • 用户注册成功后,如果三天内没有登陆则进行短信提醒
  • 用户发起退款,如果三天内没有得到处理则通知相关运营人员

这时候,延时队列就可以闪亮登场了,以上场景,正是延时队列的用武之地

2. 延时队列插件

2.1. 插件安装

RabbitMQ 3.6.x 之前我们一般采用 死信队列+ TTL 过期时间来实现延迟队列,我们这里不做过多介绍,从 RabbitMQ 3.6.x 开始,RabbitMQ 官方提供了延迟队列的插件。插件下载地址:https://www.rabbitmq.com/community-plugins.html

本人使用的 RabbitMQ 3.8.3 版本,所以下载 rabbitmq_delayed_message_exchange-3.8.0.ez 这个插件放到 RabbitMQ 安装目录的 plugins 文件中。在 RabbitMQ 安装 sbin 文件中用 cmd 执行命令

rabbitmq-plugins enable rabbitmq_delayed_message_exchange

开启插件后,启动 RabbitMQ,访问登录后访问 http://localhost:15672,在交换机 exchangestab下,底部新增将看到如下图设置,则表示插件已启动,以后直接就可以使用了

在这里插入图片描述

2.2. 插件原理

延迟插件底层简单原理图

在这里插入图片描述

  • 原始的 死信队列+ TTL 的模式,消息首先会路由到一个正常的队列,根据设置的 TTL 进入死信队列,与之不同的是通过 x-delayed-message 声明的交换机,它的消息在发布之后不会立即进入队列,先将消息保存至 Mnesia(一个分布式数据库管理系统,适合于电信和其它需要持续运行和具备软实时特性的 Erlang 应用)
  • 这个插件将会尝试确认消息是否过期,首先要确保消息的延迟范围是 Delay > 0, Delay =< ?ERL_MAX_T(在 Erlang 中可以被设置的范围为 (2^32)-1 毫秒),如果消息过期通过 x-delayed-type 类型标记的交换机投递至目标队列,整个消息的投递过程也就完成了

3. 插件实现延时队列

3.1. 消息发送方

3.1.1. 主要依赖

<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-amqp</artifactId>
 </dependency>
 <dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-starter-web</artifactId>
 </dependency>

3.1.2. 配置文件

server.port=8080

spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
#确认消息已发送到交换机
spring.rabbitmq.publisher-confirms=true
#确认消息已发送到队列
spring.rabbitmq.publisher-returns=true

3.1.3. 队列,交换机的配置绑定

@Configuration
public class RabbitConfig {
   

    // 延时交换机
    public static final String DELAY_EXCHANGE_NAME = "delay_exchange";

    // 延时队列名称
    public static final String DELAY_QUEUE_NAME = "delay_queue";

    // 普通交换机
    public static final String ORDER_PAY_Exchange_Name = "order_pay_exchange";

    // 普通队列名称
    public static final String ORDER_PAY_QUEUE_NAME = "order_pay_queue";

    // 普通交换机路由键
    public static final String ORDER_PAY_ROUTING_KEY = "order_pay_routing_key";

    // ------------------------延时队列------------------------
    // 延时队列
    @Bean
    public Queue delayPayQueue() {
   
        return new Queue(RabbitConfig.DELAY_QUEUE_NAME, true);
    }

    // 延时交换机
    public FanoutExchange delayExchange
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值