RabbitMQ-延迟队列的使用

目录

一、使用场景

二、第一种方式:创建具有超时功能且绑定死信交换机的消息队列

三、第二种方式:创建通用延时消息

四、第三种方式:使用rabbitmq的延时队列插件,实现同一个队列中有多个不同超时时间的消息,并按时间超时顺序出队

[4.1 下载延迟插件](#4.1 下载延迟插件)

[4.2 安装插件并启用](#4.2 安装插件并启用)

五、延迟队列图示

六、源代码参考


一、使用场景

  • **1.**定时发布文章
  • **2.**秒杀之后,给30分钟时间进行支付,如果30分钟后,没有支付,订单取消。
  • **3.**预约餐厅,提前半个小时发短信通知用户。

A -> 13:00 17:00 16:30 延迟时间: 7*30 * 60 * 1000

B -> 11:00 18:00 17:30 延迟时间: 13*30 * 60 * 1000

C -> 8:00 14:00 13:30 延迟时间: 11*30 * 60 * 1000

二、第一种方式:创建具有超时功能且绑定死信交换机的消息队列

java 复制代码
   @Bean
    public Queue directQueueLong(){
        return   QueueBuilder.durable("业务队列名称")
                .deadLetterExchange("死信交换机名称")
                .deadLetterRoutingKey("死信队列 RoutingKey")
                .ttl(20000) // 消息停留时间
                //.maxLength(500)
                .build();
    }

监听死信队列,即可处理超时的消息队列

缺点:

上述实现方式中,ttl延时队列中所有的消息超时时间都是一样的,如果不同消息想设置不一样的超时时间,就需要建立多个不同超时时间的消息队列,比较麻烦,且不利于维护。

三、第二种方式:创建通用延时消息

java 复制代码
rabbitTemplate.convertAndSend("交换机名称", "RoutingKey","对象",
	message => {

 
			        message.getMessageProperties().setExpiration(String.valueOf(5000))
			        return message;
	            }
           );

缺点:

该种方式可以创建一个承载不同超时时间消息的消息队列,但是这种方式有一个问题,如果消息队列中排在前面的消息没有到超时时间,即使后面的消息到了超时时间,先到超时时间的消息也不会进入死信队列,而是先检查排在最前面的消息队列是否到了超时时间,如果到了超时时间才会继续检查后面的消息。

四、第三种方式:使用rabbitmq的延时队列插件,实现同一个队列中有多个不同超时时间的消息,并按时间超时顺序出队

4.1 下载延迟插件

在 RabbitMQ 的 3.5.7 版本之后,提供了一个插件(rabbitmq-delayed-message-exchange)来实现延迟队列 ,同时需保证 Erlang/OPT 版本为 18.0 之后。

我这里 MQ 的版本是 3.10.0 现在去 GitHub 上根据版本号下载插件

https://github.com/rabbitmq/rabbitmq-delayed-message-exchange/releases

4.2 安装插件并启用

我用的是 Docker 客户端,下载完成后直接把插件放在 /root 目录,然后拷贝到容器内plugins目录下(rabbitmq是容器的name,也可以使用容器id)

java 复制代码
docker cp /opt/rabbitmq_delayed_message_exchange-3.10.0.ez rabbitmq:/plugins

进入 Docker 容器

java 复制代码
docker exec -it rabbitmq /bin/bash

在plugins内启用插件

java 复制代码
#先执行,解除防火墙限制,增加文件权限
umask 0022
rabbitmq-plugins enable rabbitmq_delayed_message_exchange

退出容器

java 复制代码
exit

重启 RabbitMQ

java 复制代码
docker restart rabbitmq

通过UI查看

五、延迟队列图示

当C端用户发出消息的时候,延迟队列会实时检测谁的时间最短,自动将最短的排在前面,一定程度上避免了阻塞

六、源代码参考

https://codeup.aliyun.com/62858d45487c500c27f5aab5/springboot-rabbitmq.git

相关推荐
xiaobaishuoAI6 小时前
分布式事务实战(Seata 版):解决分布式系统数据一致性问题(含代码教学)
大数据·人工智能·分布式·深度学习·wpf·geo
CV_J9 小时前
RabbitMQ安装
rabbitmq
程序猿阿伟10 小时前
《异步分布式训练提速关键:梯度压缩的收敛稳定性操控指南》
分布式
廋到被风吹走10 小时前
【数据库】【MongoDB】全栈深度指南:文档模型到分布式集群
数据库·分布式·mongodb
独自破碎E12 小时前
RabbitMQ怎么实现延迟消息?
rabbitmq
陌路2012 小时前
RPC分布式通信(3)--RPC基础框架接口
分布式·网络协议·rpc
小北方城市网13 小时前
SpringBoot 集成 RabbitMQ 实战(消息队列解耦与削峰):实现高可靠异步通信
java·spring boot·python·微服务·rabbitmq·java-rabbitmq·数据库架构
装不满的克莱因瓶13 小时前
【2026最新 架构环境安装篇三】Docker安装RabbitMQ4.x详细教程
linux·运维·docker·容器·架构·rabbitmq
陌路2015 小时前
RPC分布式通信(1)--分布式通信讲解
分布式·网络协议·rpc
西***634715 小时前
三大一体化音视频管理平台:技术特性与场景落地全解析
分布式