gharris1727 commented on code in PR #13178: URL: https://github.com/apache/kafka/pull/13178#discussion_r1106151656
########## connect/mirror/src/main/java/org/apache/kafka/connect/mirror/OffsetSyncStore.java: ########## @@ -16,40 +16,88 @@ */ package org.apache.kafka.connect.mirror; -import org.apache.kafka.clients.consumer.KafkaConsumer; +import org.apache.kafka.clients.admin.AdminClientConfig; +import org.apache.kafka.clients.consumer.Consumer; import org.apache.kafka.clients.consumer.ConsumerRecord; +import org.apache.kafka.clients.producer.Producer; import org.apache.kafka.common.TopicPartition; -import org.apache.kafka.common.errors.WakeupException; -import org.apache.kafka.common.serialization.ByteArrayDeserializer; +import org.apache.kafka.common.utils.Time; import org.apache.kafka.common.utils.Utils; +import org.apache.kafka.connect.util.KafkaBasedLog; +import org.apache.kafka.connect.util.TopicAdmin; -import java.util.Map; -import java.util.HashMap; import java.util.Collections; -import java.time.Duration; +import java.util.Map; import java.util.Optional; import java.util.OptionalLong; +import java.util.concurrent.ConcurrentHashMap; /** Used internally by MirrorMaker. Stores offset syncs and performs offset translation. */ class OffsetSyncStore implements AutoCloseable { - private final KafkaConsumer<byte[], byte[]> consumer; - private final Map<TopicPartition, OffsetSync> offsetSyncs = new HashMap<>(); - private final TopicPartition offsetSyncTopicPartition; + private final KafkaBasedLog<byte[], byte[]> backingStore; + private final Map<TopicPartition, OffsetSync> offsetSyncs = new ConcurrentHashMap<>(); + private final TopicAdmin admin; + private volatile boolean readToEnd = false; OffsetSyncStore(MirrorCheckpointConfig config) { - consumer = new KafkaConsumer<>(config.offsetSyncsTopicConsumerConfig(), - new ByteArrayDeserializer(), new ByteArrayDeserializer()); - offsetSyncTopicPartition = new TopicPartition(config.offsetSyncsTopic(), 0); - consumer.assign(Collections.singleton(offsetSyncTopicPartition)); + Consumer<byte[], byte[]> consumer = null; + TopicAdmin admin = null; + KafkaBasedLog<byte[], byte[]> store; + try { + Consumer<byte[], byte[]> finalConsumer = consumer = MirrorUtils.newConsumer(config.offsetSyncsTopicConsumerConfig()); Review Comment: I pulled this out to a private method which uses it's arguments as final variables. It looks a little bit less silly. -- 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