RabbitMQ 使用插件实现延时队列

本文介绍了如何使用RabbitMQ的延迟消息交换机插件实现延时队列,适用于订单超时、会议提醒等场景。相较于轮询,这种方式能节省资源并提高响应速度。详细阐述了实现方案,包括新增exchange、配置queue和消息延迟投递等步骤,同时指出该插件可能对性能的影响及不适合大数据量的延时消息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

RabbitMQ 使用插件实现延时队列

参考?:https://github.com/rabbitmq/rabbitmq-delayed-message-exchange

使用场景

  • 订单下单30分钟后,如果用户没有付款,则系统自动取消订单。
  • 会议开始前10分钟,推送消息提醒用户。
  • 自定义某个操作的执行时间,如果设置文章在明早9点发布。

优势

  • 替代轮询。

    若数据库数据量大,则定时轮询就会特别消耗资源,拖垮服务器,且响应慢。

实现方案

rabbitmq有两种方式实现延时队列。(第一种方式在同级目录下,这篇文章只写第二种方式)

方案一:是通过设置队列的Dead Letter Exchanes和队列或消息的TTL。

方案二:是通过rabbitmq_delayed_message_exchange插件。

概要

  • 新增type为x-delayed-message的exchange,必须配置x-delayed-type: topic/direct/fanout。
  • 新增队列queue1, 绑定exchange和routingkey(rountingkey根据自己的需求来,可配可不配)。
  • 生产者设置消息的delay时长并发送消息至queue1。
  • 消费者消费queue1。

具体实现

引入maven依赖

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

代码实现

@Test
  public void sendToDeadQueue20() {
      sendToDeadQueue(12);
      sendToDeadQueue(30);
      sendToDeadQueue(20);
      sendToDeadQueue(15);
      sendToDeadQueue(25);
      sendToDeadQueue(14);
      sendToDeadQueue(13);
      sendToDeadQueue(16);
      sendToDeadQueue(11);
      sendToDeadQueue(10);
  }

  public void sendToDeadQueue(Integer expire) {
      MessageProperties messageProperties = new MessageProperties();
      messageProperties.setDelay(expire * 1000);
      messageProperties.setContentType("json");
      Message message = new Message(expire.toString().getBytes(), messageProperties);
      amqpTemplate.convertAndSend("exchange", "rountingKey", message);
  }
  
  @RabbitListener(queues = "queue1")
  public void calendarPopUp(byte[] msg) {
      try {
          String s = new String(msg, "UTF-8");
          log.info(s);
      } catch (Exception e) {
          log.error("[{}]字符转换异常:", msg, e);
      }
  }

控制台输出

10

11

12

13

14

15

16

20

25

30

若delay延时时长已经过了,消费者依然会消费该消息。因为该插件实现的功能只是延时投递。经过了设置的delay时长,消息才会进入队列,并不在意消费者有无消费该队列。

该插件的影响和限制

  • 会降低性能,所以如果没有该需求,则不要使用。
  • 该插件不适合大数据量的延时消息,比如百万或一亿。
  • 延时时长:0<=n<=(2^32)-1 ,单位毫秒。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值