java中kafka消费者代码
时间: 2024-12-02 16:19:54 浏览: 47
在Java中,使用Apache Kafka作为消息队列系统,你可以通过Kafka的官方库`org.apache.kafka.clients.consumer`来编写消费者的代码。以下是一个简单的示例,展示了如何创建一个基本的Kafka消费者:
```java
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
public class KafkaConsumerExample {
private static final String BOOTSTRAP_SERVERS = "localhost:9092";
private static final String TOPIC = "your-topic";
public static void main(String[] args) {
Properties props = new Properties();
props.put("bootstrap.servers", BOOTSTRAP_SERVERS);
props.put("group.id", "test-consumer-group");
props.put("enable.auto.commit", "true");
props.put("auto.commit.interval.ms", "1000");
props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
KafkaConsumer<String, String> consumer = new KafkaConsumer<>(props);
try {
consumer.subscribe(Arrays.asList(TOPIC));
while (true) {
ConsumerRecords<String, String> records = consumer.poll(100); // 每隔100毫秒拉取消息
for (ConsumerRecord<String, String> record : records) {
System.out.printf("offset = %d, key = %s, value = %s%n", record.offset(), record.key(), record.value());
}
}
} finally {
consumer.close();
}
}
}
```
在这个例子中,我们首先设置了连接服务器、组ID等配置,然后创建了消费者实例,并订阅指定主题。接着进入一个无限循环,定期从Kafka服务器获取数据并处理。
阅读全文
相关推荐


















