首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Spring Kafka MessageListenerContainer恢复/暂停# spring-kafka

Spring Kafka MessageListenerContainer恢复/暂停# spring-kafka
EN

Stack Overflow用户
提问于 2020-07-22 19:13:45
回答 1查看 347关注 0票数 0

由于原生KafkaConsumer不是线程安全的,所以不鼓励从不同的线程调用pause和resume方法,而不是从kafka-consumer处理线程调用。但是spring-kafka提供了另一层KafkaMessageListenerContainer,在内部使用kafka-consumer。所以我的问题是,我们是否可以使用KafkaListenerEndpointRegistry通过id获取侦听器容器,并从其他线程而不是消费者处理线程调用resume或pause方法。

代码语言:javascript
运行
复制
kafkaListenerEndpointRegistry.getListenerContainer("id").pause();
       

    ExecutorService executorService  = newFixedThreadPool(2);
    executorService.submit(()->{

        System.out.println("CurrentThread: {}" + Thread.currentThread().getId()+ " " + Thread.currentThread().getName());
        try {
            Thread.sleep(5000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        kafkaListenerEndpointRegistry.getListenerContainer("id").resume();
    });
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-07-22 21:40:25

可以;container.pause()会设置一个标志,告诉Consumer线程在下一次poll()调用之前暂停。类似地,resume()重置标志,以便使用者线程在下一次轮询之前恢复Consumer

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/63032912

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档