java topicpartition,Java KafkaConsumer.listTopics方法代码示例

import org.apache.kafka.clients.consumer.KafkaConsumer; //导入方法依赖的package包/类

/**

* When an object implementing interface Runnable is used

* to create a thread, starting the thread causes the object's

* run method to be called in that separately executing

* thread.

*

* The general contract of the method run is that it may

* take any action whatsoever.

*

* @see Thread#run()

*/

@Override

public void run() {

String group = "kafka-insight-logOffsetListener";

int sleepTime = 60000;

KafkaConsumer, Array> kafkaConsumer = null;

while (true) {

try {

if (null == kafkaConsumer) {

kafkaConsumer = KafkaUtils.createNewKafkaConsumer(brokersInfo, group);

}

Map> topicPartitionsMap = kafkaConsumer.listTopics();

for (List partitionInfoList : topicPartitionsMap.values()) {

for (PartitionInfo partitionInfo : partitionInfoList) {

TopicPartition topicPartition = new TopicPartition(partitionInfo.topic(), partitionInfo.partition());

Collection topicPartitions = Arrays.asList(topicPartition);

kafkaConsumer.assign(topicPartitions);

kafkaConsumer.seekToEnd(topicPartitions);

Long logEndOffset = kafkaConsumer.position(topicPartition);

logEndOffsetMap.put(topicPartition, logEndOffset);

}

}

Thread.sleep(sleepTime);

} catch (Exception e) {

e.printStackTrace();

if (null != kafkaConsumer) {

kafkaConsumer.close();

kafkaConsumer = null;

}

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值