具有指数退避的 AMQ 消息排序

问题描述

我很好奇 AMQ 在消息重新传递和指数退避方面处理消息排序的方式。

假设您有三个消息:[M3,M2,M1]。如果我从队列的头部提取 M1 消息并且我的系统无法处理它,M1 会回到队列的头部,从而延迟它后面的所有其他消息吗?或者是否有一些巧妙的策略,将消息放在一边直到准备好传递,从而允许在 M1 之前处理消息 M2 和 M3?

解决方法

我进行了一项实验,似乎保持了严格的顺序。 M1 总是在 M2 之前被消耗掉,依此类推。