
no.nav.common.kafka.consumer.util.FeatureToggledKafkaConsumerClient Maven / Gradle / Ivy
package no.nav.common.kafka.consumer.util;
import lombok.extern.slf4j.Slf4j;
import no.nav.common.kafka.consumer.KafkaConsumerClient;
import java.time.Duration;
import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;
import java.util.function.Supplier;
/**
* {@link KafkaConsumerClient} with support for toggling the consumer on/off based off the result from a {@link Supplier}
* Use cases for this implementation is for example when there is a need to pause the consumer to change the offset and restart the client.
*/
@Slf4j
public class FeatureToggledKafkaConsumerClient implements KafkaConsumerClient {
private final static Duration DEFAULT_POLL_TIMEOUT = Duration.ofMinutes(1);
private final KafkaConsumerClient kafkaConsumerClient;
private final Duration pollTimeoutDuration;
private final Supplier isConsumerToggledOffSupplier;
private ScheduledExecutorService executorService;
public FeatureToggledKafkaConsumerClient(KafkaConsumerClient kafkaConsumerClient, Supplier isToggledOffSupplier) {
this.kafkaConsumerClient = kafkaConsumerClient;
this.isConsumerToggledOffSupplier = isToggledOffSupplier;
this.pollTimeoutDuration = DEFAULT_POLL_TIMEOUT;
}
public FeatureToggledKafkaConsumerClient(KafkaConsumerClient kafkaConsumerClient, Supplier isToggledOffSupplier, Duration pollTimeoutDuration) {
this.kafkaConsumerClient = kafkaConsumerClient;
this.isConsumerToggledOffSupplier = isToggledOffSupplier;
this.pollTimeoutDuration = pollTimeoutDuration;
}
@Override
public void start() {
if (!isRunning()) {
kafkaConsumerClient.start();
}
if (executorService != null && !executorService.isShutdown()) {
executorService.shutdown();
}
if (executorService == null || executorService.isShutdown()) {
executorService = Executors.newSingleThreadScheduledExecutor();
executorService.scheduleAtFixedRate(this::syncRunningStateWithToggle, pollTimeoutDuration.toMillis(), pollTimeoutDuration.toMillis(), TimeUnit.MILLISECONDS);
}
}
@Override
public void stop() {
if (executorService != null) {
executorService.shutdown();
}
if (isRunning()) {
kafkaConsumerClient.stop();
}
}
@Override
public boolean isRunning() {
return kafkaConsumerClient.isRunning();
}
private void syncRunningStateWithToggle() {
boolean isConsumerToggledOff = isConsumerToggledOffSupplier.get();
boolean isRunning = isRunning();
if (isConsumerToggledOff && isRunning) {
log.info("Stopping consumer... Toggle for stopping consumers is on and kafka consumer client is running");
kafkaConsumerClient.stop();
} else if (!isConsumerToggledOff && !isRunning) {
log.info("Starting consumer... Toggle for stopping consumers is off and kafka consumer client is not running");
kafkaConsumerClient.start();
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy