详情解释
其中 delivery tag 1 由rabbitMQ的tag机制表示这条消息已经完成了消费,报错的原因是因为消息已经完成了消费,所以在MQ中未找到该条消息,业务需要完成的逻辑是完成了的
这条信息表示该条消息被设定为自动确认的任务给确认了, acknowledgeMode=AUTO local queue size=0
表示队列消息长度为0
报错原因分析
当我们在项目中使用RabbitMQ将某条监听的消息进行了手动ACK确认,但由于MQ默认为当消息消费时自动确认消息,所以导致消息在刚被消费时进行了自动确认,此时又去操作了一遍手动确认,这时你的消息队列已经没有该条消息,所以手动确认时便找不到该条消息
解决方案
在配置文件中添加
acknowledge-mode: manual # 手动应答
将MQ消息的消费机制默认为手动
这是我个人的一些关于MQ的配置,有意者可以看看