我想处理消费者从队列中获取的不成功的消息并将它们重新排队。
想象一下我有这样的情况:
P => | foo | bar | baz | => C
其中 foo、bar 和 baz 是消息。
如果消费者读到baz
但出了问题,我可以使用basic.reject
or the basic.nack
( https://www.rabbitmq.com/nack.html https://www.rabbitmq.com/nack.html)。使用这两个命令之一,我将传递参数以重新排队消息。
问题是消息在之前的相同位置重新排队,因此下一条消息将是baz
again.
我想重新排队,但将其发送回队列的开头:
P => | baz | foo | bar | => C
我在应用程序上用几行代码解决了这个问题,但我想知道是否存在更好的解决方案,也许直接使用 RabbitMQ 的某些功能。
你可以看一下死信队列(DLQ):https://www.rabbitmq.com/dlx.html https://www.rabbitmq.com/dlx.html
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)