繁体   English   中英

Kafka如何知道Java中为主题创建的最新分区ID

[英]Kafka how to know the latest created partition id for a topic in Java

我正在使用AdminUtils动态创建主题分区。 我必须获取新创建的分区的partitionId才能将其保存在Mysql中以用于业务逻辑。 我该如何实现? 我当前的代码:

 AdminUtils.addPartitions(zkUtils,KAFKA_PRODUCER_TOPIC,currentPartitionCount+1,"",true);

            List<PartitionInfo> infoList = producer.partitionsFor(KAFKA_PRODUCER_TOPIC);
            for(PartitionInfo info : infoList){
                System.out.println(info.partition());
            }
            createdPartionId = infoList.get(0).partition();

上面的问题是,最新创建的分区没有出现在PartitionInfo列表中。 不知道为什么。producer是Kafka Producer API。

您可以执行TopicMetadataRequest 参见示例 您可以在前后进行比较,然后比较结果。 否则,新分区将始终添加有newPartitionID == previousLastPartitionID + 1

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM