【发布时间】:2020-02-10 18:32:43
【问题描述】:
我在 MSK(Kafka) 中创建了一个主题。 而且我还注册了 avro 模式。 现在我正在尝试为该主题生成一条消息,但是当我运行我的生产者时,我得到以下错误
java.util.concurrent.ExecutionException: org.apache.kafka.common.errors.TimeoutException: Topic AVRO-AUDIT_EVENT not present in metadata after 60000 ms.
这是我生成 avro 消息的 java 代码
String topicName = "AVRO-AUDIT_EVENT";
Properties props = new Properties();
props.put("bootstrap.servers",
"b-3.*****:9092,b-4.****:9092,b-5.****:9092");
props.put("bootstrap.servers", "localhost:9092,localhost:9093");
props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
props.put("value.serializer", "io.confluent.kafka.serializers.KafkaAvroSerializer");
props.put("schema.registry.url", "http://localhost:8081/subjects/AVRO-AUDIT-EVENT/versions/");
JSONObject job = new JSONObject(json);
String bodyofJson = job.getString("body");
JSONObject bodyJsonObj = new JSONObject(bodyofJson);
System.out.println(bodyJsonObj.get("ID"));
Producer<String, String> producer = new KafkaProducer<>(props);
try {
producer.send(new ProducerRecord<String, String>(topicName, bodyJsonObj.get("ID").toString(), bodyofJson))
.get();
System.out.println("Complete");
} catch (Exception ex) {
ex.printStackTrace(System.out);
} finally {
producer.close();
}
我可以列出主题并查看主题名称,也可以阅读主题消息。但是当我运行这个时,我得到了这个错误。
问候
【问题讨论】:
标签: java apache-kafka kafka-producer-api