[ https://issues.apache.org/jira/browse/KAFKA-19607?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Greg Harris updated KAFKA-19607: -------------------------------- Priority: Minor (was: Critical) > MirrorMaker2 Offset Replication Issue > ------------------------------------- > > Key: KAFKA-19607 > URL: https://issues.apache.org/jira/browse/KAFKA-19607 > Project: Kafka > Issue Type: Bug > Components: mirrormaker > Affects Versions: 4.0.0 > Reporter: geric > Priority: Minor > Labels: RedHat > > I am using *Apache Kafka 4.0* with *MirrorMaker 2* to link the primary > cluster ({*}clusterA{*}) to the secondary cluster ({*}clusterB{*}). > The secondary cluster will not have any producers or consumers until a > disaster recovery event occurs, at which point all producers and consumers > will switch to it. > *Setup:* > * Dedicated standalone MirrorMaker 2 node > * {{IdentityReplicationPolicy}} (no topic renaming) > * No clients connected to secondary cluster under normal operation > *MirrorMaker 2 config:* > {{# Cluster aliases > clusters = clusterA, clusterB > # Bootstrap servers > clusterA.bootstrap.servers = serverA-kafka-1:9092 > clusterB.bootstrap.servers = serverB-kafka-1:9092 > # Replication policy > replication.policy.class=org.apache.kafka.connect.mirror.IdentityReplicationPolicy > # Offset/Checkpoint sync > emit.checkpoints.enabled=true > emit.checkpoints.interval.seconds=5 > sync.group.offsets.enabled=true > sync.group.offsets.interval.seconds=5 > offset.lag.max=10 > refresh.topics.interval.seconds=5}} > ---- > h3. Test results: > # *Produce 300 messages when MirrorMaker is running* > *Expected:* Topic offset synced within a minute > *Result:* ✅ Passed > # *Consume 100 messages when MirrorMaker is running, then terminate the > consumer* > *Expected:* Consumer offset synced > *Result:* ❌ Failed — offset is not synced to clusterB > # *Restart MirrorMaker after test #2* > *Expected:* Consumer offset synced > *Result:* ✅ Passed > # *Repeat test #2 — consume 100 messages when MirrorMaker is running, then > terminate the consumer* > *Expected:* Consumer offset synced > *Result:* ❌ Failed — offset is not synced to clusterB > # *Restart MirrorMaker after test #4* > *Expected:* Consumer offset synced > *Result:* ❌ Failed — offset is not synced to clusterB > # *Consume messages but keep consumer running* > *Expected:* Offset synced > *Result:* ✅ Passed > ---- > h3. Problem: > Consumer offsets appear to only sync in these cases: > # When MirrorMaker is restarted and the consumer offset does *not* already > exist in the secondary cluster (initial sync), or > # When the consumer is still connected at the time of sync, *or* when the > consumer has reached the end of the offset (i.e., consumed all available > messages). > However, if the consumer exits immediately after consuming some messages (but > {*}before reaching the end of the topic{*}), the committed offset is *never > synced* to the target cluster. > ---- > h3. Additional Context / Related Issues > This problem seems related to an open discussion in the Apache Kafka mailing > list: > *MirrorCheckpointConnector does not replicate final batch of offsets* > [https://lists.apache.org/thread/dxn9jyotl00f7ov541299cd8tlcl1z00] -- This message was sent by Atlassian Jira (v8.20.10#820010)