Kafka抛出java.lang.NoSuchMethodException

时间:2016-03-22 02:45:52

标签: apache-kafka kafka-producer-api

我编写了自己的序列化程序来将java对象发布到主题。我将serializer.class属性设置为我的自定义序列化程序。 运行生产者时,我得到以下异常。有人可以帮助我吗?

例外

Exception in thread "main" java.lang.NoSuchMethodException: com.xxxx.CustomFileSerializer.<init>(kafka.utils.VerifiableProperties)
    at java.lang.Class.getConstructor0(Class.java:3082)
    at java.lang.Class.getConstructor(Class.java:1825)
    at kafka.utils.CoreUtils$.createObject(CoreUtils.scala:222)
    at kafka.producer.Producer.<init>(Producer.scala:62)
    at kafka.javaapi.producer.Producer.<init>(Producer.scala:26)
    at com.xx.KafkaProducer.generateMessgaes(KafkaProducer.java:50)
    at com.xx.KafkaProducer.main(KafkaProducer.java:60)

我的制作人

props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
        props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");
        props.put("serializer.class", "com.xxxx.CustomFileSerializer");


kafka.javaapi.producer.Producer<String, FileObj> producer = new kafka.javaapi.producer.Producer<String, FileObj>(
                producerConfig);
        String key = "key1";
        KeyedMessage<String, RawFile>   record = new KeyedMessage<String, RawFile>(topic, key, file);
        producer.send(record);
        producer.close();

1 个答案:

答案 0 :(得分:1)

看起来您正在使用旧的生产者使用新的序列化程序。旧序列化程序在其构造函数中采用了VerifiableProperties值。尝试新的生产者或使用Decoder的实现作为序列化器。

另请注意,使用新生成器更改了序列化程序属性名称,de / serializers实现的接口也是如此(Serializer和Deserializer而不是旧的Decoder)