KafkaConsumer assignment() returns empty(KafkaConsumer Assignment()返回空)
本文介绍了KafkaConsumer Assignment()返回空的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在使用
<dependency>
<groupId>org.apache.kafka</groupId>
<artifactId>kafka-clients</artifactId>
<version>2.0.1</version>
</dependency>
以下代码返回非空分配的分区,但poll(0)
已弃用。
val records = kafkaConsumer.poll(0) // <= deprecated
logInfo(s"Dummy call ${records.count()}")
val partitions = kafkaConsumer.assignment()
logInfo(s"partitions=${partitions}")
以下返回空分区:
val records = kafkaConsumer.poll(Duration.ofMillis(0)) // <= not working
logInfo(s"Dummy call ${records.count()}")
val partitions = kafkaConsumer.assignment()
logInfo(s"partitions=${partitions}")
为什么?有什么主意吗?谢谢
推荐答案
这两个调用的不同之处在于获取元数据的方式。被弃用的poll
会无限期地等待,直到成功检索元数据,而另一个poll
只尝试一次,通常在非常短的时间间隔内(对于您的情况是0)无法连接到协调器,并返回任何有用的东西。这就是为什么您在调用poll(Duration.ofMillis(0))
一次后会看到一个空的赋值。
这篇关于KafkaConsumer Assignment()返回空的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:KafkaConsumer Assignment()返回空


基础教程推荐
猜你喜欢
- Spring AOP错误无法懒惰地为此建议构建thisJoinPoin 2022-09-13
- 存储 20 位数字的数据类型 2022-01-01
- REST Web 服务返回 415 - 不支持的媒体类型 2022-01-01
- 无法复制:“比较方法违反了它的一般约定!" 2022-01-01
- 如何对 Java Hashmap 中的值求和 2022-01-01
- 问题http://apache.org/xml/features/xinclude测试日志4j 2 2022-01-01
- 修改 void 函数的输入参数,然后读取 2022-01-01
- 使用堆栈算法进行括号/括号匹配 2022-01-01
- RabbitMQ:消息保持“未确认"; 2022-01-01
- Struts2 URL 无法访问 2022-01-01