RabbitMQ 上的 Nack 和 reject

Nack and reject on RabbitMQ

我想处理消费者从队列中获取的不成功消息并重新排队。

假设我有这样的情况:

P => | foo | bar | baz | => C

其中 foo、bar 和 baz 是消息。

如果消费者阅读 baz 但出现问题,我可以使用 basic.rejectbasic.nack ( https://www.rabbitmq.com/nack.html )。使用这两个命令之一,我将传递参数以重新排队消息。

问题是消息在与之前相同的位置重新排队,因此下一条消息将再次 baz

我想重新排队,但将其发送回队列的开头:

P => | baz | foo | bar | => C

我在我的应用程序上用几行代码解决了它,但我想知道是否存在更好的解决方案,也许直接使用 RabbitMQ 的某些功能。

你可以看看死信队列(DLQ):https://www.rabbitmq.com/dlx.html