HaiNiuProjects/Kafka/src/main/java/com/aisi/consumer/ConsumerWithCooperativeStic...

50 lines
2.2 KiB
Java

package com.aisi.consumer;
import org.apache.kafka.clients.consumer.*;
import org.apache.kafka.common.TopicPartition;
import java.time.Duration;
import java.util.Arrays;
import java.util.Collection;
import java.util.List;
import java.util.Properties;
public class ConsumerWithCooperativeStickyAssignor {
public static void main(String[] args) {
Properties properties = new Properties();
properties.put("bootstrap.servers", "localhost:9092");
properties.put("group.id", "aisi-group");
properties.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
properties.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
//设定分区分配策略为 cooperative-sticky
properties.put("partition.assignment.strategy", CooperativeStickyAssignor.class.getName());
//设定consumer断开超时时间最小不能小于6s
properties.put("session.timeout.ms", 6000);
KafkaConsumer<String, String> consumer = new KafkaConsumer(properties);
List<String> topics = Arrays.asList("topic_d","topic_e");
consumer.subscribe(topics);
consumer.subscribe(topics, new ConsumerRebalanceListener() {
@Override
public void onPartitionsRevoked(Collection<TopicPartition> partitions) {
for (TopicPartition topicPartition : partitions) {
System.out.println("分区移除:::::"+topicPartition.topic() + ":" + topicPartition.partition());
}
}
@Override
public void onPartitionsAssigned(Collection<TopicPartition> partitions) {
for (TopicPartition topicPartition : partitions) {
System.out.println("分区添加:::::"+topicPartition.topic() + ":" + topicPartition.partition());
}
}
});
while (true) {
ConsumerRecords<String, String> records = consumer.poll(Duration.ofSeconds(1));
for (ConsumerRecord<String, String> record : records) {
System.out.println(record.topic() + "->" + record.partition() + "->" + record.offset() + "->" + record.key() + "->" + record.value());
}
}
}
}