如何使用RebbitMQ延迟交换机插件解决死信交换机队头阻塞问题

首先,在使用这个插件之前,我们先来了解一下什么叫队头阻塞?

我们如果同时发两次带有过期时间的消息时,使用TTL就会有队头阻塞问题,比如说,第一个发送的消息过期以后(10s),第二个消息不会被打印出来(5s)。

一、首先,安装插件

        1.首先将插件保存到对应目录的数据券

docker volume inspect mq-plugins

        2.将插件上传到这个目录 

        3.执行下面命令,安装插件

docker exec -it mq bash

        4.执行下面命令,开启插件

rabbitmq-plugins enable rabbitmq_delayed_message_exchange

二、DelayExchange工作原理

        1.首先,安装完插件后,我们在控制台可以看到这个地方多了一个选项        

         2.这个交换机,不仅做路由转发,还做消息存储(这就是延迟交换机和其他交换机最本质的区别)

        3.声明交换机和队列

@Slf4j
@Configuration
public class DelayConfig {
    @Bean
    public DirectExchange delayExchange(){
        return ExchangeBuilder
                .directExchange("delay.exchange")
                // 延迟交换机
                .delayed()
                .build();
    }

    @Bean
    public Queue delayQueue(){
        return new Queue("delay.queue");
    }

    @Bean
    public Binding delayBinding(){
        return BindingBuilder.bind(delayQueue()).to(delayExchange()).with("delay");
    }
}

        4.声明一个消费者

@RabbitListener(queues = "delay.queue")
public void onDelayMessage(String msg){
    log.info("收到delay.queue中的消息:{}", msg);
}

        5.消息发送进行测试

@Test
public void testSendDelayMsg(){
    String exchange = "delay.exchange";
    String routingKey = "delay";
    Message message1 = MessageBuilder
            .withBody("delay11111111".getBytes())
            .setDeliveryMode(MessageDeliveryMode.PERSISTENT)
            .setHeader("x-delay",10000)
            .build();
    rabbitTemplate.convertAndSend(exchange,routingKey,message1);
    
    Message message2 = MessageBuilder
            .withBody("delay222222222".getBytes())
            .setDeliveryMode(MessageDeliveryMode.PERSISTENT)
            .setHeader("x-delay",20000)
            .build();
    rabbitTemplate.convertAndSend(exchange,routingKey,message2);
}

  • 12
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值