报错信息:Returned message but no callback available
消息被服务器退回。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);
}