Rabbit的confirm方法判断ack的时候写日志。但是查看日志中并没有

whyyouhitme_ 2019-08-03 11:36:03
为true或false都打了日志。
但是查看日志的时候,只要发送和接收的时候的两行,并没有ack判断后的日志。
但是,既然消费成功了,那肯定是投递到了MQ,为什么没日志呢?这么做不对?
	@Override
public void confirm(CorrelationData correlationData, boolean ack, String cause) {
String jsonString = correlationData.getId();
System.out.println("消息id:" + correlationData.getId());
if (ack) {
log.info(">>>使用MQ消息确认机制确保消息一定要投递到MQ中成功");
return;
}
JSONObject jsonObject = JSONObject.parseObject(jsonString);
// 生产者消息投递失败的话,采用递归重试机制
send(jsonObject);
log.info(">>>使用MQ消息确认机制投递到MQ中失败"+cause);
}
...全文
114 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
aloneno 2019-08-07
  • 打赏
  • 举报
回复
会不会因为我这个消息投递到了MQ,但是因为MQ自身的原因,导致消息丢失,返回的ack为false,之后进入递归重试,但重试时又是相同的情况,导致无限递归,且不会打印日志

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧