通过RabbitMQ 死信队列实现延迟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", 5000);

        return new Queue(DEAD_LETTER_PROD,true,false,false,args);
    }

    @Bean(DEAD_LETTER_CONSUME)
    Queue b() {
        return new Queue(DEAD_LETTER_CONSUME);
    }

3、可能会遇到的问题:项目启动报错

请注意,在创建队列的时候,设置的3个属性,如果进行了修改,需要在MQ上删除相应的队列,然后重启项目,否则会因为客户端设置和服务器已经存在的队列属性不一致而报错,不能正常运行。

4、可能会遇到的问题:在设置了统一的过期时间后,又在某几条消息上设置了过期时间,但是预期结果不一致

第一个,当同时设置了统一过期时间,消息过期时间时,谁的值越小,则遵从谁的值
第二个,因为RabbitMQ 遵循先进先出策略,所以,如果第一条消息设置了1小时过期,第二条是30分钟,那么第二条消息会被阻塞,然后在1小时后收到2条消息。

所以,如果要使用不同的过期时间,请创建多对消息队列来实现

发布了442 篇原创文章 · 获赞 1379 · 访问量 234万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术黑板 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览