RabbitMQ之消费者批量消费
创始人
2024-11-29 13:06:36
0

为什么要用消费端批量消费?
在一些业务场景下,我们希望使用 Consumer 批量消费消息,提高消费速度。可以通过对 SimpleRabbitListenerContainerFactory 进行配置实现批量消费能力

==========================>配置类 @Configuration public class ConsumerConfiguration {     @Resource     ConnectionFactory connectionFactory;     @Resource     SimpleRabbitListenerContainerFactoryConfigurer configurer;      /**      * 配置一个批量消费的 SimpleRabbitListenerContainerFactory      */     @Bean(name = "consumer10BatchContainerFactory")     public SimpleRabbitListenerContainerFactory consumer10BatchContainerFactory() {         SimpleRabbitListenerContainerFactory factory = new SimpleRabbitListenerContainerFactory();         configurer.configure(factory, connectionFactory);         // 这里是重点 配置消费者的监听器是批量消费消息的类型         factory.setBatchListener(true);          // 一批十个         factory.setBatchSize(1000);         // 等待时间 毫秒 , 这里其实是单个消息的等待时间 指的是单个消息的等待时间         // 也就是说极端情况下,你会等待 BatchSize * ReceiveTimeout 的时间才会收到消息         factory.setReceiveTimeout(10 * 1000L);         factory.setConsumerBatchEnabled(true);          return factory;     } } ====================》生产者 @Component public class Producer10 {      @Resource     RabbitTemplate rabbitTemplate;      public void sendSingle(String id, String routingKey) {         Message10 message = new Message10();         message.setId(id);         rabbitTemplate.convertAndSend(Message10.EXCHANGE, routingKey, message);     } } ================================》消费者 @RabbitListener(queues = Message10.QUEUE, containerFactory = "consumer10BatchContainerFactory") @Component @Slf4j public class Consumer10 {     /**      * 批量消费      *      * @param message 一批消息      */     @RabbitHandler     public void onMessage(List message) {         log.info("[{}][Consumer10 批量][线程编号:{}][消息个数:{}][消息内容:{}]"                 , LocalDateTime.now()                 , Thread.currentThread().getId()                 , message.size()                 , message);     }      /**      * 单个消费      *      * @param message 一个消息      */     @RabbitHandler     public void onMessage(Message10 message) {         log.info("[{}][Consumer10 单个][线程编号:{}][消息内容:{}]"                 , LocalDateTime.now()                 , Thread.currentThread().getId()                 , message);     } } ==================================》测试类 @Test     void sendSingle() throws InterruptedException {         // 假设 一秒一个,发送 1000 个,观察消费者的情况         for (int i = 0; i < 15; i++) {             TimeUnit.SECONDS.sleep(1);             String id = UUID.randomUUID().toString();             producer10.sendSingle(id, Message10.ROUTING_KEY);             if (i == 9) {                 log.info("[{}][test producer10 sendSingle] 发送成功10个", LocalDateTime.now());             }         }         log.info("[{}][test producer10 sendSingle] 发送成功", LocalDateTime.now());          TimeUnit.SECONDS.sleep(20);     } } 

以上的是RabbitMQ之消费者批量消费实现的代码 若不了解rabbitmq的基本使用 建议先看看我前面对应的文章 文章链接:点我—>let’s go
若需完整代码 可识别二维码后 给您发代码。
在这里插入图片描述

相关内容

热门资讯

黑科技辅助!wepoke透明挂... 黑科技辅助!wepoke透明挂在哪买(透视)软件透明挂ai辅助器(一直真的是有挂)-哔哩哔哩,wep...
黑科技辅助!红龙扑克会作假(透... 黑科技辅助!红龙扑克会作假(透视)软件透明挂ai辅助工具(本来是真的有挂)-哔哩哔哩;最新版2026...
黑科技辅助!wepoke是有挂... 黑科技辅助!wepoke是有挂软件(透视)先前真的是有挂(有挂方式)-哔哩哔哩;1、完成wepoke...
黑科技辅助!红龙扑克辅助器第一... 黑科技辅助!红龙扑克辅助器第一视角(透视)软件透明挂ai辅助器(竟然存在有挂)-哔哩哔哩;黑科技辅助...
黑科技辅助!wepoke真的有... 黑科技辅助!wepoke真的有挂嘛(透视)都是存在有挂(有挂工具)-哔哩哔哩;是一款可以让一直输的玩...
黑科技辅助!德州ai辅助可以打... 黑科技辅助!德州ai辅助可以打(透视)软件透明挂ai辅助软件(素来有挂)-哔哩哔哩;1、让任何用户在...
黑科技辅助!智星菠萝德州辅助器... 黑科技辅助!智星菠萝德州辅助器(透视)原生真的有挂(详细教程)-哔哩哔哩是一款可以让一直输的玩家,快...
黑科技辅助!wpk透视辅助(透... 黑科技辅助!wpk透视辅助(透视)软件透明挂ai辅助安装(原来有挂)-哔哩哔哩;wpk透视辅助是一种...
黑科技辅助!poker外挂(透... 黑科技辅助!poker外挂(透视)素来真的是有挂(有挂详情)-哔哩哔哩;AI辅助机器人普及解说快速成...
黑科技辅助!pokerworl... 黑科技辅助!pokerworld软件(透视)软件透明挂ai辅助安装(竟然真的是有挂)-哔哩哔哩;1、...