java - Apache Kafka 异常 : org. apache.kafka.clients.consumer.KafkaConsumer.subscribe(Ljava/util/List;)V

标签 java apache-kafka kafka-consumer-api nosuchmethoderror

我使用的是 Apache Kafka 版本 kafka_2.10-0.10.1.0

在 Poc 期间,我创建了简单的生产者和消费者。 当我尝试使用消息时出现以下错误:

 Exception in thread "Thread-0" java.lang.NoSuchMethodError: org.apache.kafka.clients.consumer.KafkaConsumer.subscribe(Ljava/util/List;)V
at com.spnotes.kafka.simple.Consumer$ConsumerThread.run(Consumer.java:59)

代码:

package com.spnotes.kafka.simple;

import org.apache.kafka.clients.consumer.ConsumerConfig;
import org.apache.kafka.clients.consumer.ConsumerRecord;
import org.apache.kafka.clients.consumer.ConsumerRecords;
import org.apache.kafka.clients.consumer.KafkaConsumer;
import org.apache.kafka.common.errors.WakeupException;

import java.util.Arrays;
import java.util.Properties;
import java.util.Scanner;


public class Consumer {
    private static Scanner in;

    public static void main(String[] argv)throws Exception{
        if (argv.length != 2) {
            System.err.printf("Usage: %s <topicName> <groupId>\n",
                    Consumer.class.getSimpleName());
            System.exit(-1);
        }
        in = new Scanner(System.in);
        String topicName = argv[0];
        String groupId = argv[1];

        ConsumerThread consumerRunnable = new ConsumerThread(topicName,groupId);
        consumerRunnable.start();
        String line = "";
        while (!line.equals("exit")) {
            line = in.next();
        }
        consumerRunnable.getKafkaConsumer().wakeup();
        System.out.println("Stopping consumer .....");
        consumerRunnable.join();
    }

    private static class ConsumerThread extends Thread{
        private String topicName;
        private String groupId;
        private KafkaConsumer<String,String> kafkaConsumer;

        public ConsumerThread(String topicName, String groupId){
            this.topicName = topicName;
            this.groupId = groupId;
        }
        public void run() {
            Properties configProperties = new Properties();
            configProperties.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "localhost:9092");
            configProperties.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.ByteArrayDeserializer");
            configProperties.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, "org.apache.kafka.common.serialization.StringDeserializer");
            configProperties.put(ConsumerConfig.GROUP_ID_CONFIG, groupId);
            configProperties.put(ConsumerConfig.CLIENT_ID_CONFIG, "simple");

            //Figure out where to start processing messages from
            kafkaConsumer = new KafkaConsumer<String, String>(configProperties);
            kafkaConsumer.subscribe(Arrays.asList(topicName));
            //Start processing messages
            try {
                while (true) {
                    ConsumerRecords<String, String> records = kafkaConsumer.poll(100);
                    for (ConsumerRecord<String, String> record : records)
                        System.out.println(record.value());
                }
            }catch(WakeupException ex){
                System.out.println("Exception caught " + ex.getMessage());
            }finally{
                kafkaConsumer.close();
                System.out.println("After closing KafkaConsumer");
            }
        }
        public KafkaConsumer<String,String> getKafkaConsumer(){
           return this.kafkaConsumer;
        }
    }
}

使用命令破坏:

java -cp .:/home/osboxes/Kafka/kafka_2.10-0.10.1.1/libs/*:/home/osboxes/Kafka/kafka_2.10-0.10.1.1/libs/KafkaAPIClient-1.0-SNAPSHOT.jar  com.spnotes.kafka.simple.Consumer test group1

错误:

Exception in thread "Thread-0" java.lang.NoSuchMethodError: org.apache.kafka.clients.consumer.KafkaConsumer.subscribe(Ljava/util/List;)V
    at com.spnotes.kafka.simple.Consumer$ConsumerThread.run(Consumer.java:59)

最佳答案

感谢 amethystic,我使用了错误的 API。 添加新客户端版本后开始工作

旧的 API 在 POM 中

   <dependency>
        <groupId>org.apache.kafka</groupId>
        <artifactId>kafka-clients</artifactId>
        <version>0.9.0.0</version>
    </dependency>

在 POM 中添加了新的 API

   <dependency>
        <groupId>org.apache.kafka</groupId>
        <artifactId>kafka-clients</artifactId>
        <version>0.10.0.0</version>
    </dependency>

Kafka API新旧版本不向后兼容

关于java - Apache Kafka 异常 : org. apache.kafka.clients.consumer.KafkaConsumer.subscribe(Ljava/util/List;)V,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41410151/

相关文章:

java - Spring Kafka - 选择 @TopicPartition 会停用组中的消费者

Spring Cloud 流式传输并消费多个 kafka 主题

apache-kafka - Kafka消费者再平衡算法

java - Kafka Consumer仅在产生 'enough'数据后才读取

java - 更新子文档的所有元素,其中子文档是列表的一部分

Java:用对象填充 JComboBox

java - 如何在Tomcat V6.0.45中运行Spring 3.2项目

java - 使用 struts2 预填充表单元素并进行验证错误

mysql - 如何在kafka jdbc连接源中过滤数据库中的表

apache-spark - 基于 Direct Stream 的 Spark Streaming 与 Kafka 仅显示一个消费者 ID