activemq解决消费不均匀_ActiveMQ多个消费者消费不均匀问题(转)

本文介绍了ActiveMQ中消费不均匀的问题及解决方案,主要关注预取限制(prefetch limit)的设置。当消费者处理速度慢时,Broker会停止发送新消息。不同消费者类型的默认预取限制不同,如Queue consumer默认为1000。优化策略包括针对Queue消费者设置较小的预取限制(如0或1),以及对Durable topic subscribers增大预取限制以提升性能。预取限制可在Broker端或消费者端设置,并可通过代码示例进行详细配置。
摘要由CSDN通过智能技术生成

原文:http://blog.csdn.net/u010310183/article/details/51690876

先上图

如果客户端处理很慢的话,Broker会在之前发送消息的反馈之前

如果客户端处理很慢的话,Broker会在之前发送消息的反馈之前,继续发送新的消息到客户端。如果客户端依旧很慢的话,没有得到确认反馈的消息会持续增长。在这种情况下,Broker有可能会停止发送消息给消费者。当未被反馈的消息达到了prefetch

limit

设置的数字时,Broker将会停止给消费者发送新的消息。除非消费者开始给与反馈,否则得不到任何消息。

[html] view plain

copy

Default Prefetch Limit(默认预取限制):不同的消费者类型有不同的默认设置,具体设置如下:

Queue consumer

:默认1000

如果你使用一组消费者进行分散工作量的话(一个Queue对应多个消费者),典型的你应该把数字设置的小一些。如果一个消费者被允许可以聚集大量的未被确认的消息的话,会导致其它的消费者无事可做。同时,如果这个消费者出错的话,会导致大量的消息不能被处理,直到消费者恢复之前。

Queue browser

:默认500

Topic consumer

:默认32766

默认值32766是数字short的最大值,也是预取限制的最大值。

Durable topic subscriber

:默认100

通常你可以通过增加预取限制来改善性能。

<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值