问题描述:
使用了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); }