当前位置:   article > 正文

通过RabbitMQ 死信队列实现延迟MQ消息,消息延迟,MQ延迟队列_mq查询死信队列

mq查询死信队列

通过RabbitMQ 死信队列实现延迟MQ消息,消息延迟,MQ延迟队列


1、延迟消息原理

客户端向MQ服务器发送一条队列消息,该消息设置了TTL【该消息在超过TTL的时间内没有被消费,就会被视为是死信】,但是不给该队列提供消费者,在消息超时后,由死信交换机转发该消息到指定的消费者,以实现延迟队列。

简单点说,就是向一个没有消费者的队列发送一条有过期机制的消息,消息过期后死信交换机DLK把消息转发给一个没有生产者的队列,以实现消费。

2、如何在Springboot 下创建延迟消息队列

只需要正常的创建2个队列,然后设置三个属性即可创建延迟消息队列

    @Bean(DEAD_LETTER_PROD)
    Queue a() {
        Map<String,Object> args = Maps.newHashMap();
        // RabbitMqExchange.ExchangeCenter.DEAD_LETTER_EXCHANGE_CONSUME  只是一个交换机的名称,可以按需要定义
        args.put("x-dead-letter-exchange", RabbitMqExchange.ExchangeCenter.DEAD_LETTER_EXCHANGE_CONSUME);
        // 消息过期转发到那个队列去
        args.put("x-dead-letter-routing-key", DEAD_LETTER_CONSUME);
        // 消息超时
        args.put("x-message-ttl
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/神奇cpp/article/detail/930152
推荐阅读
相关标签
  

闽ICP备14008679号