解决RabbitMQ队列超长QueueingCons…

本文讲述了在使用RabbitMQ时遇到队列超长,导致服务器内存占用过高的情况。通过jstat和jmap分析,发现是由于QueueingConsumer持有大量对象引发的内存溢出。解决方案是调用Channel的basicQos方法,限制临时内存中保存的消息数,以避免类似问题的发生。合理设置QoS参数是避免RabbitMQ队列雪崩的关键。
摘要由CSDN通过智能技术生成
      我们的服务器使用RabbitMQ作为消息中转的容器。某天我怀疑RabbitMQ队列 是否都能及时消化。于是用命令查询了下:rabbitmqctl list_vhosts | grep -P ".*\.host" | xargs -i rabbitmqctl list_queues -p {} | grep "queue"。   不查不知道,一查吓一跳:大多数服务器的队列基本上都是空的,但是有些服务器的某个队列竟然有超过500W条的记录。一般 RabbitMQ进程占用内存不过100M-200M,这些队列超长的 RabbitMQ 进程可以占用超过2G的内存。
        显然消息队列的消费者出现了问题。开发查看日志发现作为该队列消费者的Java服务的日志也卡住了,重启服务 (这点做得不对,应该用jstat、jstack进行排查,而不是直接重启
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值