1 package de.juplo.kafka;
3 import org.apache.kafka.clients.consumer.Consumer;
4 import org.springframework.boot.autoconfigure.kafka.KafkaProperties;
5 import org.springframework.boot.context.properties.EnableConfigurationProperties;
6 import org.springframework.context.annotation.Bean;
7 import org.springframework.context.annotation.Configuration;
9 import org.springframework.kafka.core.ConsumerFactory;
11 import java.util.concurrent.ExecutorService;
12 import java.util.concurrent.Executors;
16 @EnableConfigurationProperties({ KafkaProperties.class, ApplicationProperties.class })
17 public class ApplicationConfiguration
20 public SimpleConsumer endlessConsumer(
21 Consumer<String, String> kafkaConsumer,
22 ExecutorService executor,
23 KafkaProperties kafkaProperties,
24 ApplicationProperties applicationProperties)
29 kafkaProperties.getClientId(),
30 applicationProperties.getTopic(),
35 public ExecutorService executor()
37 return Executors.newSingleThreadExecutor();
40 @Bean(destroyMethod = "close")
41 public Consumer<String, String> kafkaConsumer(ConsumerFactory<String, String> factory)
43 return factory.createConsumer();