X-Git-Url: http://juplo.de/gitweb/?a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fkafka%2FEndlessConsumer.java;h=929bdbd5ccf659c20cf86005686ed94406d7d7c6;hb=9b3731e4a7aeca27f7ba11502bc7f0a66c1d22b8;hp=87780b4e3cc22d679452a10abecd5dcafc30b885;hpb=a9200a876060edc8683dfd6d0d16c23407c189ad;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 87780b4..929bdbd 100644 --- a/src/main/java/de/juplo/kafka/EndlessConsumer.java +++ b/src/main/java/de/juplo/kafka/EndlessConsumer.java @@ -8,6 +8,7 @@ import org.springframework.beans.factory.annotation.Value; import org.springframework.kafka.annotation.KafkaListener; import org.springframework.stereotype.Component; +import java.util.List; import java.util.function.Consumer; @@ -22,19 +23,24 @@ public class EndlessConsumer Consumer> handler; - @KafkaListener(topics = "${consumer.topic}") - public void receive(ConsumerRecord record) + @KafkaListener(topics = "${consumer.topic}", containerFactory = "batchFactory") + public void receive(List> records) { - log.info( - "{} - {}: {}/{} - {}={}", - id, - record.offset(), - record.topic(), - record.partition(), - record.key(), - record.value() - ); + // Do something with the data... + log.info("{} - Received {} messages", id, records.size()); + for (ConsumerRecord record : records) + { + log.info( + "{} - {}: {}/{} - {}={}", + id, + record.offset(), + record.topic(), + record.partition(), + record.key(), + record.value() + ); - handler.accept(record); + handler.accept(record); + } } }