RabbitMQ笔记(七)-SimpleMessageListenerContainer和DirectMessageListenerContainer

本文介绍了RabbitMQ中两种监听器容器SimpleMessageListenerContainer和DirectMessageListenerContainer的区别。SimpleMessageListenerContainer默认启动单个消费者,支持并发性和动态调整,而DirectMessageListenerContainer需要配置任务执行器以支持并发性,且在运行时添加和删除队列更有效,避免了上下文切换。两者在事务处理和线程使用上有所不同,适用于不同的场景需求。
摘要由CSDN通过智能技术生成

在版本2.0之前的版本中,只有一种MessageListenerContainer—SimpleMessageListenerContainer;

2.0之后有第二个容器——DirectMessageListenerContainer

SimpleMessageListenerContainer

默认情况下,侦听器容器将启动单个使用者,该使用者将从队列接收消息。

在检查上一节中的表时,您将看到许多控制并发性的属性。最简单的是concurrentConsumers,它只创建(固定的)将并发处理消息的使用者数量。

此外,还添加了一个新的属性maxConcurrentConsumers,容器将根据工作负载动态调整并发性。这与四个附加属性一起工作:continutiveactivetrigger、startConsumerMinInterval、continutiveidletrigger、stopConsumerMinInterval。

在默认设置下,增加消费者的算法工作如下:

如果尚未到达maxConcurrentConsumers,并且已有的使用者连续10个周期处于活动状态,并且自上一个使用者启动以来至少已经过了10秒,那么将启动一个新的使用者。如果使用者在txSize *中接收到至少一条消息,则认为该使用者处于活动状态。

在默认设置下,减少消费者的算法工作如下:

如果有多个concurrentConsumers正在运行,并且某个consumer检测到10个连续超时(空闲),并且上一个consumer至少在60秒之前停止,那么该consumer将停止。超时取决于receiveTimeout和txSize属性。如果使用者在txSize *中没有接收到任何消息,则认为它是空闲的。因此,

  • 14
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值