3 ActiveMQ 特性 - 消费者(同步和异步调度)

ActiveMQ 特性 - 消费者(同步和异步调度)

读完该片文章,你将会了解:

  1. 代理(broker)是否需要开启异步发送消息到消费者。
  2. 如何开启异步发送消息。
  3. 如何关闭异步发送消息。

消费者异步调度

概述

在AMQ4时,代理(broker)同步或异步调度消息到消费者就是可配置的。现在我们也可以通过uri链接、connection 和 connectionFactory 的形式配置,这种方式的配置可以替代以前那种只能通过在broker端方式的配置。

无论同步或异步调度消息都是非常有意义的,因为针对消费比较快的消费者,我们使用同步(可以减少异步发送消息时产生的上下文切换),针对消费比较慢的消费者,我们使用异步。 同步调度消息的缺点是,对于生产者发送的消息,如果消费者消费的比较慢,那么生产者就会被阻塞。

默认配置是异步发送 (displayatchAsync=true),这种配置也保证了MQ的高性能。建议不要修改成同步,除非你非常确定,几乎不存在慢速消费者,这时同步才会提高吞吐率。
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-SAjrekQo-1576940810204)(https://img-blog.csdn.net/20151220194545182 “broker 同步或异步调度消息 模型”)]

通过 ConnectionFactory 设置异步

((ActiveMQConnectionFactory)connectionFactory).setDispatchAsync(true);

通过 Connection 设置异步

在此处设置的异步,将会覆盖 ConnectionFactory 的配置。

通过 Consumer 设置异步

queue = new ActiveMQQueue("TEST.QUEUE? consumer.dispatchAsync=false");
consumer = session.createConsumer(queue);

在代理端(broker)强制同步

可以在代理端设置 disableAsyncDispatch 来关闭异步,一旦针对某个通信通道关闭了异步发送,客户端将不能再开启异步。

<transportConnector name="openwire" uri="tcp://0.0.0.0:61616" disableAsyncDispatch="true" />
发布了31 篇原创文章 · 获赞 30 · 访问量 52万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览