KafkaConsumer Assignment()返回空

时间:2019-04-25 22:20:47

标签: java scala apache-kafka kafka-consumer-api

我正在使用

<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}")

为什么?有任何想法吗?谢谢

1 个答案:

答案 0 :(得分:0)

这两个调用的区别在于元数据的获取方式。已弃用的poll无限期等待,直到成功检索元数据为止,而另一个poll仅尝试一次,通常在非常短的时间间隔(对于您的情况为0)内无法连接到协调器,然后返回没有任何用处。这就是为什么在调用poll(Duration.ofMillis(0))一次之后看到空的分配的原因。