RabbitMq重复签收问题
Channel shutdown: channel error; protocol method: #method<channel.close>(reply-code=406, reply-text=PRECONDITION_FAILED - unknown delivery tag 1, class-id=60, method-id=80)
在配置文件中配置了手动签收
spring:
rabbitmq:
host: 000
port: 5672
username: 000
password: 000
virtual-host: /000
publisher-returns: true
listener:
simple:
acknowledge-mode: manual # 手动应答
prefetch: 1 #每次从队列中取一个,轮询分发,默认是公平分发
retry:
max-attempts: 5 # 重试次数
enabled: true # 开启重试
消费者处理,在处理的时候,签收了两次
try{
...这里一堆逻辑...
// 处理完之后手动签收
channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);
} catch (Exception e) {
log.error("【传播渠道记录1】 接收到消息为:" + skuIdStr + " ,消息异常消费 : ", e);
} finally {
// 处理完之后手动签收(这里再次签收)
//两次签收就会报这个错误,只能签收一次
channel.basicAck(message.getMessageProperties().getDeliveryTag(), false);
}
消费者内部重复签收导致签收异常。。。。
文章描述了一个在使用RabbitMQ时遇到的问题,即由于消费者在处理消息后手动签收了两次,导致出现`PRECONDITION_FAILED-unknowndeliverytag`错误。配置文件设置了手动签收模式和重试机制,消费者代码中在try-catch-finally块中都包含了一次`basicAck`调用,从而引发了签收异常。解决方法是删除不必要的第二次签收操作。
5万+

被折叠的 条评论
为什么被折叠?



