X-Git-Url: http://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2FEndlessConsumer.java;h=5e768651daccdef99f175b2aa7ef829f901c6285;hb=85929b7925a1afcddf6fd8b6e650ba4057be3e4d;hp=929bdbd5ccf659c20cf86005686ed94406d7d7c6;hpb=9b3731e4a7aeca27f7ba11502bc7f0a66c1d22b8;p=demos%2Fkafka%2Ftraining diff --git a/src/main/java/de/juplo/kafka/EndlessConsumer.java b/src/main/java/de/juplo/kafka/EndlessConsumer.java index 929bdbd..5e76865 100644 --- a/src/main/java/de/juplo/kafka/EndlessConsumer.java +++ b/src/main/java/de/juplo/kafka/EndlessConsumer.java @@ -6,6 +6,7 @@ import org.apache.kafka.clients.consumer.ConsumerRecord; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.kafka.annotation.KafkaListener; +import org.springframework.kafka.config.KafkaListenerEndpointRegistry; import org.springframework.stereotype.Component; import java.util.List; @@ -17,13 +18,21 @@ import java.util.function.Consumer; @RequiredArgsConstructor public class EndlessConsumer { + @Autowired + private KafkaListenerEndpointRegistry registry; @Value("${consumer.client-id}") String id; @Autowired Consumer> handler; + private long consumed = 0; - @KafkaListener(topics = "${consumer.topic}", containerFactory = "batchFactory") + @KafkaListener( + id = "${consumer.client-id}", + idIsGroup = false, + topics = "${consumer.topic}", + containerFactory = "batchFactory", + autoStartup = "false") public void receive(List> records) { // Do something with the data... @@ -41,6 +50,28 @@ public class EndlessConsumer ); handler.accept(record); + + consumed++; } } + + + public synchronized void start() + { + if (registry.getListenerContainer(id).isChildRunning()) + throw new IllegalStateException("Consumer instance " + id + " is already running!"); + + log.info("{} - Starting - consumed {} messages before", id, consumed); + registry.getListenerContainer(id).start(); + } + + public synchronized void stop() + { + if (!registry.getListenerContainer(id).isChildRunning()) + throw new IllegalStateException("Consumer instance " + id + " is not running!"); + + log.info("{} - Stopping", id); + registry.getListenerContainer(id).stop(); + log.info("{} - Stopped - consumed {} messages so far", id, consumed); + } }