mirror of https://github.com/apache/kafka.git
KAFKA-15695: Update the local log start offset of a log after rebuilding the auxiliary state (#14649)
Reviewers: Satish Duggana <satishd@apache.org>, Luke Chen <showuon@gmail.com>, Divij Vaidya <diviv@amazon.com>, Kamal Chandraprakash<kamal.chandraprakash@gmail.com>, Alexandre Dupriez <alexandre.dupriez@gmail.com>
This commit is contained in:
parent
c5ee82cab4
commit
be531c681c
|
@ -229,8 +229,11 @@ public class ReplicaFetcherTierStateMachine implements TierStateMachine {
|
|||
Partition partition = replicaMgr.getPartitionOrException(topicPartition);
|
||||
partition.truncateFullyAndStartAt(nextOffset, false, Option.apply(leaderLogStartOffset));
|
||||
|
||||
// Build leader epoch cache.
|
||||
// Increment start offsets
|
||||
unifiedLog.maybeIncrementLogStartOffset(leaderLogStartOffset, LeaderOffsetIncremented);
|
||||
unifiedLog.maybeIncrementLocalLogStartOffset(nextOffset, LeaderOffsetIncremented);
|
||||
|
||||
// Build leader epoch cache.
|
||||
List<EpochEntry> epochs = readLeaderEpochCheckpoint(rlm, remoteLogSegmentMetadata);
|
||||
if (unifiedLog.leaderEpochCache().isDefined()) {
|
||||
unifiedLog.leaderEpochCache().get().assign(epochs);
|
||||
|
|
|
@ -972,7 +972,7 @@ class UnifiedLog(@volatile var logStartOffset: Long,
|
|||
}
|
||||
}
|
||||
|
||||
private def maybeIncrementLocalLogStartOffset(newLocalLogStartOffset: Long, reason: LogStartOffsetIncrementReason): Unit = {
|
||||
def maybeIncrementLocalLogStartOffset(newLocalLogStartOffset: Long, reason: LogStartOffsetIncrementReason): Unit = {
|
||||
lock synchronized {
|
||||
if (newLocalLogStartOffset > localLogStartOffset()) {
|
||||
_localLogStartOffset = newLocalLogStartOffset
|
||||
|
@ -1815,6 +1815,7 @@ class UnifiedLog(@volatile var logStartOffset: Long,
|
|||
leaderEpochCache.foreach(_.clearAndFlush())
|
||||
producerStateManager.truncateFullyAndStartAt(newOffset)
|
||||
logStartOffset = logStartOffsetOpt.getOrElse(newOffset)
|
||||
if (remoteLogEnabled()) _localLogStartOffset = newOffset
|
||||
rebuildProducerState(newOffset, producerStateManager)
|
||||
updateHighWatermark(localLog.logEndOffsetMetadata)
|
||||
}
|
||||
|
|
|
@ -3646,6 +3646,12 @@ class UnifiedLogTest {
|
|||
log.maybeIncrementLogStartOffset(newLogStartOffset, LogStartOffsetIncrementReason.SegmentDeletion)
|
||||
assertEquals(newLogStartOffset, log.logStartOffset)
|
||||
assertEquals(log.logStartOffset, log.localLogStartOffset())
|
||||
|
||||
// Truncate the local log and verify that the offsets are updated to expected values
|
||||
val newLocalLogStartOffset = 60L;
|
||||
log.truncateFullyAndStartAt(newLocalLogStartOffset, Option.apply(newLogStartOffset))
|
||||
assertEquals(newLogStartOffset, log.logStartOffset)
|
||||
assertEquals(newLocalLogStartOffset, log.localLogStartOffset())
|
||||
}
|
||||
|
||||
private class MockLogOffsetsListener extends LogOffsetsListener {
|
||||
|
|
Loading…
Reference in New Issue