搜尋

首頁  >  問答  >  主體

如何用Java向kafka發送json數據

在網路上都只看到一些Java生產STRING類型的消息。
依照Java的producer類別來看,是可以自訂發送訊息的類型,例如producer.send(new KeyedMessage<String, HashMap<String , String>>(topic,message);
可是這樣運行會報錯,報錯如下,請求高人解答:
Exception in thread "Thread-4" java.lang.ClassCastException: java.util.HashMap cannot be cast to java.lang.String

#
at kafka.serializer.StringEncoder.toBytes(Encoder.scala:46)
at kafka.producer.async.DefaultEventHandler$$anonfun$serialize.apply(DefaultEventHandler.scala:130)
at kafka.producer.async.DefaultEventHandler$$anonfun$serialize.apply(DefaultEventHandler.scala:125)
at scala.collection.IndexedSeqOptimized$class.foreach(IndexedSeqOptimized.scala:33)
at scala.collection.mutable.WrappedArray.foreach(WrappedArray.scala:34)
at kafka.producer.async.DefaultEventHandler.serialize(DefaultEventHandler.scala:125)
at kafka.producer.async.DefaultEventHandler.handle(DefaultEventHandler.scala:52)
at kafka.producer.Producer.send(Producer.scala:77)
at kafka.javaapi.producer.Producer.send(Producer.scala:33)
at com.Model.Producer.kafkaProducer.run(kafkaProducer.java:35)
我想大声告诉你我想大声告诉你2787 天前1248

全部回覆(1)我來回復

  • 过去多啦不再A梦

    过去多啦不再A梦2017-05-17 10:07:08

    文檔,序列化成String就行了

    回覆
    0
  • 取消回覆