KafkaProducerConfig.java 1.4 KB

123456789101112131415161718192021222324252627282930313233
  1. package com.zt.config;
  2. import com.zt.commons.KafkaMessage;
  3. import org.apache.kafka.clients.producer.ProducerConfig;
  4. import org.apache.kafka.common.serialization.StringSerializer;
  5. import org.springframework.beans.factory.annotation.Value;
  6. import org.springframework.context.annotation.Bean;
  7. import org.springframework.context.annotation.Configuration;
  8. import org.springframework.kafka.core.DefaultKafkaProducerFactory;
  9. import org.springframework.kafka.core.KafkaTemplate;
  10. import org.springframework.kafka.core.ProducerFactory;
  11. import org.springframework.kafka.support.serializer.JsonSerializer;
  12. import java.util.HashMap;
  13. import java.util.Map;
  14. @Configuration
  15. public class KafkaProducerConfig {
  16. @Value("${spring.kafka.bootstrap-servers}")
  17. private String bootstrapServers;
  18. @Bean
  19. public ProducerFactory<String, KafkaMessage> producerFactory(){
  20. Map<String,Object> configProps=new HashMap<>();
  21. configProps.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,bootstrapServers);
  22. configProps.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
  23. configProps.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, JsonSerializer.class);
  24. return new DefaultKafkaProducerFactory<>(configProps);
  25. }
  26. @Bean
  27. public KafkaTemplate<String,KafkaMessage> kafkaTemplate(){
  28. return new KafkaTemplate<>(producerFactory());
  29. }
  30. }