美文网首页Java 杂谈互联网科技
ActiveMQ多个消费者消费不均匀问题

ActiveMQ多个消费者消费不均匀问题

作者: Java黎先生 | 来源:发表于2018-08-30 23:13 被阅读2次

如果客户端处理很慢的话,Broker会在之前发送消息的反馈之前,继续发送新的消息到客户端。如果客户端依旧很慢的话,没有得到确认反馈的消息会持续增长。在这种情况下,Broker有可能会停止发送消息给消费者。当未被反馈的消息达到了prefetch limit设置的数字时,Broker将会停止给消费者发送新的消息。除非消费者开始给与反馈,否则得不到任何消息。

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

Queue consumer:默认1000

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

Queue browser:默认500

Topic consumer:默认32766

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

Durable topic subscriber:默认100

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

Optimizing prefetch limits(优化预取限制):通常的,优化Queue消费和持久化主题订阅者(durable topic subscriber)是个好主意。

Queue consumers—如果你的queue只有一个消费者的话,你可以设置预取限制为一个相当大的值。但,如果一个queue有一组消费者的话,你最好限制到一个比较小的数字上,比如0或者1.

Durable topic subscribers—通常增大预取限制的数量会提高性能。尝试一下增加到1000.

How to set prefectch limits(如何设置预取限制):你可以在Broker端或者消费者端设置预取制限。这有三种粒度的设置方式。如下:

java写法

ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory();

Properties props = new Properties();

props.setProperty("prefetchPolicy.queuePrefetch", "1000");

props.setProperty("prefetchPolicy.queueBrowserPrefetch", "500");

props.setProperty("prefetchPolicy.durableTopicPrefetch", "100");

props.setProperty("prefetchPolicy.topicPrefetch", "32766");

factory.setProperties(props);

Per destination:一个最好的粒度,你可以在创建消费者的时候设置每个目的的预取限制。消费queue,TEST.QUEUE,时指定预取限制为10.创建MessageConsumer 实例的代码如下:

Queue queue =

new ActiveMQQueue("TEST.QUEUE?consumer.prefetchSize=10");

MessageConsumer consumer = session.createConsumer(queue);

Java高架构师、分布式架构、高可扩展、高性能、高并发、性能优化、Spring boot、Redis、ActiveMQ、Nginx、Mycat、Netty、Jvm大型分布式项目实战学习架构师之路想要学习以上内容进群:835638062免费学习,进群获取全套架构师视频、笔记、源码、课件、等书籍资料

相关文章

  • ActiveMQ多个消费者消费不均匀问题

    如果客户端处理很慢的话,Broker会在之前发送消息的反馈之前,继续发送新的消息到客户端。如果客户端依旧很慢的话,...

  • ActiveMQ多个消费者消费不均匀问题

    如果客户端处理很慢的话,Broker会在之前发送消息的反馈之前,继续发送新的消息到客户端。如果客户端依旧很慢的话,...

  • 后端 activemq队列模式下的多个消费者问题

    问题 最近在项目中使用了 activemq 进行消息的异步传递,只有一个消费者时,系统可以正常运行,但当增加多个消...

  • ActiveMQ

    1.pom依赖 2.启动ActiveMQ 3、activeMQ的生产者 4、activeMQ的消费者 5、消息监听

  • 2020-03-24 ActiveMQ使用

    1.前面我们学习到ActiveMQ等消息中间件的作用是一种生产者和消费者的模式,生产者只有一个,消费者可以有多个,...

  • 第2章 2-4经典同步问题

    1.生产者—消费者问题 The proceducer – consumer problem:多个生产者和消费者对n...

  • 生产者和消费者问题

    /*需求:生产者消费者问题,多个生产者和多个消费者。仓库里面没有商品是,不在消费,生产者生产商品;仓库中有商品时,...

  • activeMQ-04Java实现通讯(主题TOPIC)

    回顾下,activeMQ的发布/订阅模式(topic主题)特点:1)每一个消息可以有多个消费者,即一对多的关系;2...

  • 中间件技术ActiveMQ消息中间件的使用

    一. ActiveMQ介绍 通过ActiveMQ消息服务交换消息。消息生产者将消息发送至消息服务,消息消费者则从消...

  • java笔记--多生产多消费问题

    单一生产者,消费者问题: 多生产多消费问题: 如果直接创建多个线程,会出现生产一次,却消费多次的冲突,或者生产多个...

网友评论

    本文标题:ActiveMQ多个消费者消费不均匀问题

    本文链接:https://www.haomeiwen.com/subject/qtjjwftx.html