在使用 kafkaProducer.send()
方法发送消息之前,请确保已经在 Kafka 服务器上创建了相应的主题。你可以尝试通过使用 Kafka Command Line Interface (CLI) 来创建主题,或者通过使用 Kafka Manager 或集成开发环境 (IDE) 中的 Kafka 插件来创建主题。以下是使用 Kafka CLI 创建主题的示例:
bin/kafka-topics.sh --create --zookeeper localhost:2181 --replication-factor 1 --partitions 1 --topic my-topic
在发送消息时,请确保使用正确的主题名称。如果你在代码中拼写错误或者错误地引用主题名称,那么消息将无法发送到主题。以下是发送消息的示例:
kafka:ProducerConfiguration producerConfig = {
bootstrapServers: "localhost:9092",
clientId: "my-prod1",
acks: "all"
};
kafka:Producer producer = new(producerConfig);
public function sendToTopic(message string, topicName string) returns error? {
message msg = check new(message);
var result = producer->send(msg, topicName);
match result {
error err => {
log:printError("Unable to send message to Kafka topic: " + topicName + err.message());
return err;
}
kafka:RecordMetadata metadata => {
log:printInfo("Message sent with topic: " + metadata.topic() + " and offset: " + metadata.offset());
return ();
}
}
}
请注意,我们在 producer->send()
方法中传递了正确的 topicName
参数。
确保 Kafka 服务器在运行并且可以访问。你可以尝试在本地访问以下 URL 来验证 Kafka 服务器是否可用: http://localhost:9092/
。如果可以访问,那么你应该看到一个消息类似