ActiveMQ 特性 - 消费者(同步和异步调度)
读完该片文章,你将会了解:
- 代理(broker)是否需要开启异步发送消息到消费者。
- 如何开启异步发送消息。
- 如何关闭异步发送消息。
消费者异步调度
概述
在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" />