WIP
[demos/kafka/training] / src / main / java / de / juplo / kafka / Application.java
1 package de.juplo.kafka;
2
3 import lombok.extern.slf4j.Slf4j;
4 import org.apache.kafka.clients.consumer.Consumer;
5 import org.springframework.beans.factory.annotation.Autowired;
6 import org.springframework.boot.ApplicationArguments;
7 import org.springframework.boot.ApplicationRunner;
8 import org.springframework.boot.SpringApplication;
9 import org.springframework.boot.autoconfigure.SpringBootApplication;
10 import org.springframework.context.annotation.Bean;
11 import org.springframework.kafka.core.ConsumerFactory;
12
13 import javax.annotation.PreDestroy;
14
15
16 @SpringBootApplication
17 @Slf4j
18 public class Application implements ApplicationRunner
19 {
20   @Autowired
21   Consumer<String, Message> consumer;
22   @Autowired
23   SimpleConsumer simpleConsumer;
24
25
26   @Override
27   public void run(ApplicationArguments args) throws Exception
28   {
29     log.info("Starting EndlessConsumer");
30     simpleConsumer.start();
31   }
32
33   @PreDestroy
34   public void shutdown()
35   {
36     log.info("Signaling the consumer to quit its work");
37     consumer.wakeup();
38   }
39
40   @Bean(destroyMethod = "close")
41   public Consumer<String, Message> kafkaConsumer(ConsumerFactory<String, Message> factory)
42   {
43     return factory.createConsumer();
44   }
45
46
47   public static void main(String[] args)
48   {
49     SpringApplication.run(Application.class, args);
50   }
51 }