Linux 拨号vps windows公众号手机端

java怎么从kafka中读取数据

lewis 8年前 (2017-11-11) 阅读数 11 #程序编程
文章标签 Javakafka

在Java中,你可以使用Apache Kafka的Java客户端库来从Kafka中读取数据。下面是一个简单的示例代码:

首先,你需要在你的项目中添加Kafka的Java客户端库的依赖。你可以在你的构建工具(如Maven或Gradle)的配置文件中添加以下依赖:

<!-- Kafka client -->
<dependency>
    <groupId>org.apache.kafka</groupId>
    <artifactId>kafka-clients</artifactId>
    <version>2.8.0</version>
</dependency>

然后,你可以使用以下代码从Kafka中读取数据:

import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.common.serialization.StringDeserializer;

import java.util.Collections;
import java.util.Properties;

public class KafkaConsumerExample {
    public static void main(String[] args) {
        // Kafka集群的地址
        String bootstrapServers = "localhost:9092";
        // 消费者组的ID
        String groupId = "my-group";
        // 要消费的主题
        String topic = "my-topic";

        // 配置消费者的属性
        Properties properties = new Properties();
        properties.put("bootstrap.servers", bootstrapServers);
        properties.put("group.id", groupId);
        properties.put("key.deserializer", StringDeserializer.class);
        properties.put("value.deserializer", StringDeserializer.class);

        // 创建消费者
        KafkaConsumer<String, String> consumer = new KafkaConsumer<>(properties);

        // 订阅主题
        consumer.subscribe(Collections.singletonList(topic));

        // 无限循环从Kafka中读取消息
        while (true) {
            ConsumerRecords<String, String> records = consumer.poll(1000);
            for (ConsumerRecord<String, String> record : records) {
                System.out.println("Received message: " + record.value());
            }
        }
    }
}

以上代码创建了一个消费者并订阅了一个主题。然后,通过调用consumer.poll(1000)来从Kafka中拉取数据。在这个例子中,我们只是简单地将接收到的消息打印到控制台上。

请确保替换bootstrapServersgroupIdtopic为你要连接的Kafka集群的地址、你的消费者组的ID和你要消费的主题。

希望对你有帮助!

版权声明

本文仅代表作者观点,不代表米安网络立场。

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

热门