gpt4 book ai didi

php - 如何使用 php-rdkafka 在 kafka 中确认消费消息?

转载 作者:行者123 更新时间:2023-12-04 21:18:33 34 4
gpt4 key购买 nike

我正在使用 php-rdkafka作为 php kafka 客户端。我使用 test 成功生成了我的测试消息group.and 使用以下代码使用消息,

$kafkaConsumer = new RdKafka\Consumer();
$kafkaConsumer->addBrokers("127.0.0.1:9292");
$topic = $kafkaConsumer->newTopic("test");
$topic->consumeStart(0, RD_KAFKA_OFFSET_BEGINNING);

while (true) {
$msg = $topic->consume(0, 1000);
if($msg){
if ($msg->err) {
echo $msg->errstr(), "\n";
break;
} else {
echo $msg->payload, "\n";
}
}
}

但是当我再次尝试在 test 中设置消息时组并尝试为 test 消费消息组然后我收到旧消息和新消息。所以我只想知道如何确认旧消息,这样我只能收到新消息而不是旧消息?有人可以对此大放异彩吗?

我的kafka版本是 0.11.0.1

最佳答案

在 Kafka 中确认消费消息的方法是提交其偏移量。这样,在重新启动消费者时,它可以检索上次提交的偏移量并从停止的地方重新启动。

正如评论中所建议的,您需要使用 RD_KAFKA_OFFSET_STORED指示消费者检索存储的偏移量。

但是您还需要通过设置 group.id 来提供组名。配置:

<?php

$conf = new RdKafka\Conf();

// Set the group id. This is required when storing offsets on the broker
$conf->set('group.id', 'myConsumerGroup');

$rk = new RdKafka\Consumer($conf);
$rk->addBrokers("127.0.0.1:9292");

$topicConf = new RdKafka\TopicConf();
$topicConf->set('auto.commit.interval.ms', 100);

// Set where to start consuming messages when there is no initial offset in
// offset store or the desired offset is out of range.
// 'smallest': start from the beginning
$topicConf->set('auto.offset.reset', 'smallest');

$topic = $rk->newTopic("test", $topicConf);

// Start consuming partition 0
$topic->consumeStart(0, RD_KAFKA_OFFSET_STORED);

while (true) {
$message = $topic->consume(0, 120*10000);
switch ($message->err) {
case RD_KAFKA_RESP_ERR_NO_ERROR:
var_dump($message);
break;
case RD_KAFKA_RESP_ERR__PARTITION_EOF:
echo "No more messages; will wait for more\n";
break;
case RD_KAFKA_RESP_ERR__TIMED_OUT:
echo "Timed out\n";
break;
default:
throw new \Exception($message->errstr(), $message->err);
break;
}
}
?>

关于php - 如何使用 php-rdkafka 在 kafka 中确认消费消息?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46730967/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com