jolshan commented on a change in pull request #9590:
URL: https://github.com/apache/kafka/pull/9590#discussion_r539741047



##########
File path: 
clients/src/main/java/org/apache/kafka/common/record/MemoryRecords.java
##########
@@ -198,7 +198,7 @@ private static FilterResult filterTo(TopicPartition 
partition, Iterable<MutableR
             if (!retainedRecords.isEmpty()) {
                 if (writeOriginalBatch) {
                     batch.writeTo(bufferOutputStream);
-                    filterResult.updateRetainedBatchMetadata(batch, 
retainedRecords.size(), false);
+                    filterResult.updateRetainedBatchMetadata(batch, 
retainedRecords.get(0).offset(), retainedRecords.size(), false);

Review comment:
       Another option I considered that could give the exact offset without 
changing any offsets in the log would be to handle the listOffset request for 
the earliest timestamp on compacted topics differently. Instead of grabbing the 
log start offset, it could behave as though the request was a call for 
timestamp 0 and search for the first offset that is >=0 (as it does for any 
other timestamp search) Would this be a preferable solution if we wanted to 
ensure the exact offset?




----------------------------------------------------------------
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.

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


Reply via email to