我有我的自定义Java对象,并希望能够充分利用JVM的内置序列化将其发送到卡夫卡的话题,但系列化失败,下面的错误发送自定义Java对象卡夫卡主题
org.apache.kafka。 common.errors.SerializationException:不能类com.spring.kafka.Payload的 值转换为org.apache.kafka.common.serialization.ByteArraySerializer指定 类 value.serializer
有效载荷。 java
public class Payload implements Serializable {
private static final long serialVersionUID = 123L;
private String name="vinod";
private int anInt = 5;
private Double aDouble = new Double("5.0");
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAnInt() {
return anInt;
}
public void setAnInt(int anInt) {
this.anInt = anInt;
}
public Double getaDouble() {
return aDouble;
}
public void setaDouble(Double aDouble) {
this.aDouble = aDouble;
}
}
在我的创作制片人,我有以下的属性中设置
<entry key="key.serializer"
value="org.apache.kafka.common.serialization.ByteArraySerializer" />
<entry key="value.serializer"
value="org.apache.kafka.common.serialization.ByteArraySerializer" />
我发送调用是如下
kafkaProducer.send(new ProducerRecord<String, Payload>("test", new Payload()));
什么是发送自定义Java对象正确的方法通过制作人制作一个卡夫卡主题?
另一种选择是转换成JSON格式发送 – ravthiru