首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如果我们没有在kafka中使用delivery回调,那么在produce之后调用poll()有什么意义吗?

在Kafka中,poll()方法主要用于消费者(Consumer)从Kafka集群中拉取消息。如果你没有使用生产者的delivery回调,那么在produce之后调用poll()对于生产者(Producer)来说并没有直接的意义。

基础概念

  1. Kafka Producer: 负责将消息发送到Kafka集群。
  2. Kafka Consumer: 负责从Kafka集群中消费消息。
  3. delivery回调: 生产者在发送消息后,可以通过设置回调函数来获取消息发送的结果,包括成功或失败的信息。

为什么调用poll()没有意义

  • 生产者(Producer): 生产者的主要任务是发送消息到Kafka集群。调用poll()方法是消费者的行为,用于从Kafka集群中拉取消息。因此,生产者在调用produce()发送消息后,调用poll()是没有意义的。
  • 消费者(Consumer): 消费者通过调用poll()方法从Kafka集群中拉取消息。如果生产者没有使用delivery回调,那么生产者在发送消息后无法直接获取消息发送的结果。

解决方案

如果你是生产者,并且希望在发送消息后获取发送结果,应该使用delivery回调。以下是一个简单的示例代码:

代码语言:txt
复制
Properties props = new Properties();
props.put("bootstrap.servers", "localhost:9092");
props.put("key.serializer", "org.apache.kafka.common.serialization.StringSerializer");
props.put("value.serializer", "org.apache.kafka.common.serialization.StringSerializer");

Producer<String, String> producer = new KafkaProducer<>(props);

producer.send(new ProducerRecord<>("my-topic", "key", "value"), new Callback() {
    @Override
    public void onCompletion(RecordMetadata metadata, Exception exception) {
        if (exception != null) {
            exception.printStackTrace();
        } else {
            System.out.println("Message sent to topic: " + metadata.topic() + " partition: " + metadata.partition() + " offset: " + metadata.offset());
        }
    }
});

producer.close();

参考链接

如果你是消费者,并且需要从Kafka集群中拉取消息,那么调用poll()方法是正确的做法。以下是一个简单的示例代码:

代码语言:txt
复制
Properties props = new Properties();
props.put("bootstrap.servers", "localhost:9092");
props.put("group.id", "test");
props.put("key.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");
props.put("value.deserializer", "org.apache.kafka.common.serialization.StringDeserializer");

KafkaConsumer<String, String> consumer = new KafkaConsumer<>(props);
consumer.subscribe(Arrays.asList("my-topic"));

while (true) {
    ConsumerRecords<String, String> records = consumer.poll(Duration.ofMillis(100));
    for (ConsumerRecord<String, String> record : records) {
        System.out.printf("offset = %d, key = %s, value = %s%n", record.offset(), record.key(), record.value());
    }
}

参考链接

总结来说,生产者在发送消息后调用poll()是没有意义的,应该使用delivery回调来获取消息发送的结果。消费者则需要调用poll()方法来拉取消息。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

领券