rabbitMQ 延迟队列插件强制调用ReturnCallback里returnedMessage方法

报错信息

消息被服务器退回。msg:�� sr java.lang.Integer⠤���8 I valuexr java.lang.Number������  xp   
, replyCode:312. replyText:NO_ROUTE, exchange:my-mq-exchange_D, routingKey :spring-boot-routingKey_D
[RabbitMQ 消息发送结果:]  成功!消息唯一标识:b58e22fb-aa2b-4eb4-b8d4-6465fc26dd40

问题描述:

使用了x-delayed-message 延迟插件,结果每次都强制触发returnedMessage回调方法????

解决方案

如果配置了发送回调ReturnCallback,插件延迟队列则会回调该方法,因为发送方确实没有投递到队列上,只是在交换器上暂存,等过期时间到了 才会发往队列。

并非是BUG,而是有原因的,建议利用if 去拦截这个异常,判断延迟队列交换机名称,然后break;

    @Override
    public void returnedMessage(Message message, int replyCode, String replyText, String exchange, String routingKey) {
        //请注意!如果你使用了延迟队列插件,那么一定会调用该callback方法,因为数据并没有提交上去,而是提交在交换器中,过期时间到了才提交上去,并非是bug!你可以用if进行判断交换机名称来捕捉该报错
        if(exchange.equals(RabbitConfig.EXCHANGE_D)){
            return;
        }
        logger.info("消息被服务器退回。msg:{}, replyCode:{}. replyText:{}, exchange:{}, routingKey :{}",
                new String(message.getBody()), replyCode, replyText, exchange, routingKey);
    }

参考来源:https://my.oschina.net/xiaominmin/blog/4503811

已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 技术黑板 设计师:CSDN官方博客 返回首页