Lianet Magrans created KAFKA-19259:
--------------------------------------
Summary: Async consumer fetch intermittent delays on console
consumer
Key: KAFKA-19259
URL: https://issues.apache.org/jira/browse/KAFKA-19259
Project: Kafka
Issue Type: Bug
Components: clients, consumer
Affects Versions: 4.0.0
Reporter: Lianet Magrans
We noticed that fetching with the kafka-console-consumer.sh tool using the new
consumer shows some intermittent delays, that are not seen when running the
same with the classic consumer. Note that I disabled auto-commit to isolate the
delay, and from a first look seems to come from the fetchBuffer.awaitNonEmpty
logic, that alternatively takes almost the full poll timeout (runs "fast", then
"slow", and continues to alternate)
[https://github.com/apache/kafka/blob/0b81d6c7802c1be55dc823ce51729f2c6a6071a7/clients/src/main/java/org/apache/kafka/clients/consumer/internals/AsyncKafkaConsumer.java#L1808]
The difference in behaviour between the 2 consumers can be seen with this setup:
* topic with 6 partitions (I tried with 1 partition first and didn't see the
delay, then with 3 and 6 I could see it)
* data populated in topic with producer sending generated uuids to the topic
in while loop
* run console consumer (asycn) no commit:
bin/kafka-console-consumer.sh --topic t1 --bootstrap-server localhost:9092
--consumer-property group.protocol=consumer --group cg1 --consumer-property
enable.auto.commit=false
Here we can notice the pattern that looks like batches, and custom logs on the
awaitNonEmpty show it take the full poll timeout on alternate poll iterations.
* run same but for classic consumer (consumer-property group.protocol=classic)
-> not such pattern of intermittent delays
This needs more investigation to fully understand if it's indeed something in
the fetch path or something else)
--
This message was sent by Atlassian Jira
(v8.20.10#820010)