@Configuration @ConditionalOnClass(SimpleRabbitListenerContainerFactory.class) public class ConsumerConfig { @Value("${rabbit.batch.num:100}") private int batchNum; @Bean("batchQueueRabbitListenerContainerFactory") public SimpleRabbitListenerContainerFactory batchQueueRabbitListenerContainerFactory(ConnectionFactory connectionFactory) { SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory(); factory.setConnectionFactory(connectionFactory); factory.setBatchListener(true); factory.setConsumerBatchEnabled(true); factory.setBatchSize(batchNum); factory.setConcurrentConsumers(5); // 设置并发消费者数量为 5 factory.setMaxConcurrentConsumers(10); // 设置最大并发消费者数量为 10 return factory; } }
concurrentConsumers 和 maxConcurrentConsumers 属性的具体含义如下:
concurrentConsumers:指定同时运行的消费者数量,默认为1。
maxConcurrentConsumers:指定允许的最大并发消费者数量,默认为1。
因此,在上述示例中,设置了 concurrentConsumers 为 5,maxConcurrentConsumers 为 10,意味着 RabbitMQ 容器将维持一个初始的消费者池大小为 5,并在需要时最多扩展到 10 个并发消费者。
通过以上修改,你就可以在 batchQueueRabbitListenerContainerFactory 中控制消费者的并发数量了。根据你的实际需求,可以调整并发消费者的数量以满足系统性能和资源的要求。
需要注意的是,这种设置会影响到特定队列的消费者并发数量,而不会影响其他队列的消费者。因为你是针对特定的batchQueueRabbitListenerContainerFactory进行配置,所以只会影响使用该工厂的队列。
如果你想配置多个工厂,可以继续添加其他的@Bean方法。
例如,你可以添加另一个SimpleRabbitListenerContainerFactory bean,命名为anotherQueueRabbitListenerContainerFactory,并配置相应的属性:
@Bean("anotherQueueRabbitListenerContainerFactory") public SimpleRabbitListenerContainerFactory anotherQueueRabbitListenerContainerFactory(ConnectionFactory connectionFactory) { SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory(); factory.setConnectionFactory(connectionFactory); // 配置其他属性 return factory; }
通过这种方式,你可以定义多个SimpleRabbitListenerContainerFactory bean,并分别配置每个工厂需要的属性。然后在需要使用特定工厂的@RabbitListener注解中,通过containerFactory属性指定使用哪个工厂。
举个例子,如果你希望某个队列使用anotherQueueRabbitListenerContainerFactory工厂进行监听,可以这样设置:
@RabbitListener(queues = "another.queue", containerFactory = "anotherQueueRabbitListenerContainerFactory") public void onAnotherMessage(Message message) { // 处理消息 }
通过这种方式,你可以根据需要定义多个工厂,并将它们分配给不同的队列进行监听。
以下是rabbitMq监听消息代码:
@RabbitListener(queues = "test.queue", containerFactory = "batchQueueRabbitListenerContainerFactory") @RabbitHandler public void onReportMessage(Listmessages) { List
猜你喜欢
- 18小时前打败一切NeRF! 3D Gaussian Splatting 的 简单入门知识
- 18小时前前端超好玩的小游戏合集来啦--周末两天用html5做一个3D飞行兔子萝卜小游戏
- 18小时前宋氏家族(宋氏家族的后人们现在怎么样)
- 16小时前浙江传媒学院(浙江传媒学院硕士点)
- 15小时前小考成绩怎么查(小考成绩怎么查2024山西)
- 13小时前manage是什么意思(manage是什么意思翻译)
- 7小时前完整的西瓜可以放多久(完整的西瓜一般可以放多久)
- 5小时前顺丰特惠和标准快递有什么区别(顺丰特惠和标准快递时间一样吗)
- 5小时前除夕夜守岁打一歇后语(除夕夜守岁打歇后语是什么)
- 4小时前钻石辨别真假小窍门(钻石怎么辨别真假详见天然钻石协会)
网友评论
- 搜索
- 最新文章
- 热门文章