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" />
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值