KafkaConfig.java 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. package com.example.course.utils;
  2. import org.apache.kafka.clients.consumer.ConsumerConfig;
  3. import org.apache.kafka.clients.producer.ProducerConfig;
  4. import org.apache.kafka.common.serialization.StringDeserializer;
  5. import org.apache.kafka.common.serialization.StringSerializer;
  6. import org.springframework.context.annotation.Bean;
  7. import org.springframework.context.annotation.Configuration;
  8. import org.springframework.kafka.annotation.EnableKafka;
  9. import org.springframework.kafka.config.ConcurrentKafkaListenerContainerFactory;
  10. import org.springframework.kafka.config.KafkaListenerContainerFactory;
  11. import org.springframework.kafka.core.*;
  12. import org.springframework.kafka.listener.ConcurrentMessageListenerContainer;
  13. import org.springframework.kafka.listener.ContainerProperties;
  14. import java.util.HashMap;
  15. import java.util.Map;
  16. @Configuration
  17. @EnableKafka
  18. public class KafkaConfig {
  19. @Bean
  20. public ProducerFactory<String, String> producerFactory() {
  21. Map<String, Object> configProps = new HashMap<>();
  22. configProps.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "47.240.226.34:9092");
  23. configProps.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
  24. configProps.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
  25. configProps.put(ProducerConfig.ACKS_CONFIG, "all");
  26. configProps.put(ProducerConfig.RETRIES_CONFIG, 3);
  27. return new DefaultKafkaProducerFactory<>(configProps);
  28. }
  29. @Bean
  30. public KafkaTemplate<String, String> kafkaTemplate() {
  31. return new KafkaTemplate<>(producerFactory());
  32. }
  33. @Bean
  34. public ConsumerFactory<String, String> consumerFactory() {
  35. Map<String, Object> configProps = new HashMap<>();
  36. configProps.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, "47.240.226.34:9092");
  37. configProps.put(ConsumerConfig.GROUP_ID_CONFIG, "my-group");
  38. configProps.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
  39. configProps.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
  40. configProps.put(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG, "earliest");
  41. configProps.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, false);
  42. return new DefaultKafkaConsumerFactory<>(configProps);
  43. }
  44. @Bean
  45. public KafkaListenerContainerFactory<ConcurrentMessageListenerContainer<String, String>> kafkaListenerContainerFactory() {
  46. ConcurrentKafkaListenerContainerFactory<String, String> factory =
  47. new ConcurrentKafkaListenerContainerFactory<>();
  48. factory.setConsumerFactory(consumerFactory());
  49. factory.setConcurrency(3);
  50. factory.getContainerProperties().setPollTimeout(3000);
  51. factory.getContainerProperties().setAckMode(ContainerProperties.AckMode.MANUAL_IMMEDIATE);
  52. return factory;
  53. }
  54. }