chia7712 commented on code in PR #19295: URL: https://github.com/apache/kafka/pull/19295#discussion_r2016187929
########## clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareConsumerImpl.java: ########## @@ -644,8 +645,12 @@ private ShareFetch<K, V> collect(Map<TopicIdPartition, NodeAcknowledgements> ack if (currentFetch.isEmpty()) { final ShareFetch<K, V> fetch = fetchCollector.collect(fetchBuffer); if (fetch.isEmpty()) { + // Check for any acknowledgements which could have come from control records (GAP) and include them. + Map<TopicIdPartition, NodeAcknowledgements> combinedAcknowledgements = new LinkedHashMap<>(acknowledgementsMap); + combinedAcknowledgements.putAll(fetch.takeAcknowledgedRecords()); + // Fetch more records and send any waiting acknowledgements - applicationEventHandler.add(new ShareFetchEvent(acknowledgementsMap)); + applicationEventHandler.add(new ShareFetchEvent(combinedAcknowledgements)); Review Comment: @ShivsundarR thanks for explanation, and I have a follow-up question. > But here as fetch.isEmpty() only checks for numRecords() == 0, when the fetch is empty, we actually ignore the fetch here(meaning we never acknowledge these control records) - `fetch.isEmpty() ` means all batches have no `inFlightRecords` and `acknowledgements`, right? ```java public boolean isEmpty() { return inFlightRecords.isEmpty() && acknowledgements.isEmpty(); } ``` https://github.com/apache/kafka/blob/trunk/clients/src/main/java/org/apache/kafka/clients/consumer/internals/ShareInFlightBatch.java#L116 -- This is an automated message from the Apache Git Service. To respond to the message, please log on to GitHub and use the URL above to go to the specific comment. To unsubscribe, e-mail: jira-unsubscr...@kafka.apache.org For queries about this service, please contact Infrastructure at: us...@infra.apache.org