【RabbitMQ】RabbitMQ 消息的堆积问题 —— 使用惰性队列解决消息的堆积问题_rabbitmq出现消息堆积

对于普通的消息队列,如果没有开启消息的持久化,所有进入队列的消息通常都会保存在内存中,以提高消息的处理速度。然而,内存是有限的资源,RabbitMQ 通常会设置内存使用的预警值,通常为内存的40%。在消息堆积的情况下,可能会达到这个内存预警值。

此时,RabbitMQ 将采取一系列措施,通常被称为 “Paged Out”,以防止内存耗尽。这包括将超过内存预警值的消息刷出到磁盘上,从而释放一部分内存。同时,RabbitMQ 还会阻止新的消息进入队列,以避免进一步的内存消耗。这一系列过程会导致 RabbitMQ 进入间歇性的暂停状态,阻止了生产者的写入请求,最终导致消息队列的并发能力出现忽高忽低的情况,性能变得不够稳定。

相比之下,惰性队列将消息直接写入磁盘,难以达到内存预警值,从而提供了更稳定的性能。然而,由于涉及磁盘的读写操作,性能可能会受到一定的限制。在选择队列类型时,需要权衡内存和磁盘的使用情况,根据具体的应用需求和性能要求来做出决策。

2.2 惰性队列的声明方式

  1. 使用命令行设置惰性队列

要将队列设置为惰性队列,可以通过命令行工具来实现,同时这个方式也可以将运行中的队列设置为惰性队列。以下是在 RabbitMQ 中使用命令设置队列为惰性队列:

rabbitmqctl set_policy Lazy "^lazy-queue$" '{"queue-mode":"lazy"}' --apply-to queues

对上面命令的解释:

  • rabbitmqctl:RabbitMQ 的命令行工具,用于执行 RabbitMQ 相关操作。
  • set_policy:命令用于添加一个策略。
  • Lazy:策略的名称,您可以根据需要自定义策略名称。
  • "^lazy-queue$":使用正则表达式来匹配队列的名称。这里的正则表达式匹配队列名为 “lazy-queue” 的队列。
  • '{"queue-mode":"lazy"}':设置队列的模式为 “lazy”,这将使队列成为惰性队列。
  • --apply-to queues:指定策略应用于队列。这表示正在为队列应用 “lazy” 模式。
  • 11
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值