原文来自RabbitMQ官网:Queue Length Limit — RabbitMQ。
可以将队列的最大长度限制为一组消息或一组字节数(所有消息体长度的总和,忽略消息属性和任何开销),或两者都限制。
当设置了最大消息队列或者大小后,RabbitMQ的默认行为是丢弃队列前面的消息或死信消息(即队列中最老的消息)。若要修改此行为,请使用overflow设置。
使用overflow设置来配置队列溢出行为。如果overflow设置为reject-publish或者reject-publish-dlx,则丢弃最近发布的消息。此外,如果publisher confirms已启用,发布者将通过basic.nack消息通知发布者拒绝。如果消息被路由到多个队列并被其中至少一个队列拒绝,通道将通过basic.nack通知发布者。消息仍将被发布到所有其他可以将其排队的队列中。reject-publish和reject-publish-dlx的区别在于reject-publish-dlx也是死信被拒绝的消息。
在声明过程中使用x参数定义最大队列长度:
最大消息数可以通过设置队列声明参数x-max-length,值为非负整数。
最大字节长度可以通过设置队列声明参数x-max-length-bytes,值为非负整数。
如果两个参数都被设置,则先达到哪个上限就执行哪个。
溢出行为可以通过设置队列声明参数x-overflow。可能的值是drop-head(默认),reject-publish或reject-publish-dlx。