springCloud_day07(MQ高级)

MQ 高级 - 01. 课程介绍

MQ 高级 - 02. 发送者可靠性 - 发送者重连

MQ 高级 - 03. 发送者可靠性 - 发送者确认机制

MQ 高级 - 04. 发送者可靠性 - 发送者确认的代码实现

MQ 高级 - 05.MQ 可靠性 - 数据持久化

MQ 高级 - 06.MQ 可靠性 - LazyQueue

MQ 高级 - 07. 消费者可靠性 - 消费者确认机制

MQ 高级 - 08. 消费者可靠性 - 消费者失败重试策略

MQ 高级 - 09. 消费者可靠性 - 业务幂等处理

MQ 高级 - 10. 延迟消息 - 什么是延迟消息

MQ 高级 - 11. 延迟消息 - 死信交换机

问题:解释下面代码?

这段代码的核心是:通过消息后置处理器给单条消息设置 TTL 过期时间,结合死信队列机制,让消息在指定时间后自动转发到死信队列,实现延迟消费,是死信队列实现延迟消息的核心生产者逻辑。(使用的是消息后置处理器)

问题:死信队列实现延迟消息

二、死信队列实现延迟消息的原理

核心思路:利用 "消息过期" 变成死信,转发到死信队列,实现延迟效果。

流程:

  1. 创建一个普通队列(不设置消费者),只用来让消息等待过期
  2. 给这个队列设置 TTL(过期时间)
  3. 给这个队列绑定 死信交换机 + 死信路由键
  4. 消息发送到这个队列 → 等待过期 → 变成死信
  5. 自动转发到 死信交换机 → 死信队列
  6. 消费者监听死信队列,消费时就实现了 "延迟执行"

一句话总结:让消息在一个没人消费的队列里等一会儿,过期后再进入真正的消费队列。

  1. 配置类:声明交换机、队列、绑定
java 复制代码
@Configuration
public class DeadLetterConfig {

    // ======================= 1. 死信交换机、死信队列 =======================
    @Bean
    public DirectExchange deadLetterExchange() {
        return new DirectExchange("dead.direct");
    }

    @Bean
    public Queue deadLetterQueue() {
        return QueueBuilder.durable("dead.queue").build();
    }

    @Bean
    public Binding deadLetterBinding() {
        return BindingBuilder.bind(deadLetterQueue())
                .to(deadLetterExchange())
                .with("dead");
    }

    // ======================= 2. 延迟队列(TTL队列,无消费者) =======================
    @Bean
    public Queue ttlQueue() {
        return QueueBuilder.durable("ttl.queue")
                // 消息过期时间:10秒
                .ttl(10000)
                // 配置死信交换机
                .deadLetterExchange("dead.direct")
                // 死信路由键
                .deadLetterRoutingKey("dead")
                .build();
    }

    @Bean
    public DirectExchange ttlExchange() {
        return new DirectExchange("ttl.direct");
    }

    @Bean
    public Binding ttlBinding() {
        return BindingBuilder.bind(ttlQueue())
                .to(ttlExchange())
                .with("ttl");
    }
}

四、消息生产者(发送延迟消息)

java 复制代码
@Service
public class DelayProducer {

    @Autowired
    private RabbitTemplate rabbitTemplate;

    public void sendDelayMsg(String msg) {
        // 发送到 TTL 队列(没人消费,等待10秒过期)
        rabbitTemplate.convertAndSend(
                "ttl.direct",   // TTL交换机
                "ttl",          // 路由键
                msg             // 消息内容
        );
    }
}

五、消费者(监听死信队列 → 延迟执行)

java 复制代码
@Component
public class DeadLetterConsumer {

    // 监听死信队列
    @RabbitListener(queues = "dead.queue")
    public void listen(String msg) {
        System.out.println("【延迟消费】收到消息:" + msg);
        System.out.println("延迟时间:10秒");
        
        // 这里可以写业务:订单超时取消、关单、回滚库存...
    }
}

MQ 高级 - 12. 延迟消息 - 延迟消息插件

问题:怎么将普通交换机改造为延迟交换机?

下图的两种方式,其实只要加上delayed即可(注解/bean方式)


注意:

延迟消息插件内部会维护一个本地数据库表,同时使用Elang Timers功能实现计时。如果消息的延迟时间设置较长,可能会导致堆积的延迟消息非常多,会带来较大的CPU开销,同时延迟消息的时间会存在误差。

因此,不建议设置延迟时间过长的延迟消息

MQ 高级 - 13. 延迟消息 - 取消超时订单

末尾页

相关推荐
NHuan^_^3 小时前
SpringBoot3 整合 SpringAI 实现ai助手(记忆)
java·人工智能·spring boot
Mr_Xuhhh3 小时前
从ArrayList到LinkedList:理解链表,掌握Java集合的另一种选择
java·数据结构·链表
错把套路当深情3 小时前
Java 全方向开发技术栈指南
java·开发语言
han_hanker3 小时前
springboot 一个请求的顺序解释
java·spring boot·后端
杰克尼4 小时前
SpringCloud_day05
后端·spring·spring cloud
MaCa .BaKa4 小时前
44-校园二手交易系统(小程序)
java·spring boot·mysql·小程序·maven·intellij-idea·mybatis
希望永不加班4 小时前
SpringBoot 静态资源访问(图片/JS/CSS)配置详解
java·javascript·css·spring boot·后端
oh LAN4 小时前
RuoYi-Vue-master:Spring Boot 4.x (JDK 17+) (环境搭建)
java·vue.js·spring boot
ch.ju4 小时前
Java程序设计(第3版)第二章——java的数据类型:小数
java