spring boot kafka多数据源的使用和动态配置topic

1、pom

 <dependency>
       <groupId>org.springframework.kafka</groupId>
       <artifactId>spring-kafka</artifactId>
 </dependency>

2、properties

#============== kafka one===================
spring.kafka.one.bootstrap-servers=${
    
    kafka_bootstrap_servers:ip:port}
#===============one consumer =======================
spring.kafka.one.consumer.group-id=id
spring.kafka.one.consumer.auto-offset-reset=earliest
spring.kafka.one.consumer.enable-auto-commit=true
spring.kafka.one.consumer.auto-commit-interval=100
spring.kafka.one.consumer.max-poll-records=500

#============== kafka two===================
spring.kafka.two.bootstrap-servers=${
    
    kafka_bootstrap_servers:ip:port}
#============two consumer =======================
spring.kafka.two.consumer.group-id=id
spring.kafka.two.consumer.auto-offset-reset=earliest
spring.kafka.two.consumer.enable-auto-commit=true
spring.kafka.two.consumer.auto-commit-interval=100
spring.kafka.two.consumer.max-poll-records=500

3、config

kafka one的配置

/**
 * @author code
 * @version 1.0
 * @Date 2022/6/22 13:47
 * @Description ${kafka-one}
 */
@EnableKafka
@Configuration
public class KafkaConfigOne {
    
    

    @Value("${spring.kafka.one.bootstrap-servers}")
    private String bootstrapServers;
    @Value("${spring.kafka.one.consumer.group-id}")
    private String groupId;
    @Value("${spring.kafka.one.consumer.enable-auto-commit}")
    private boolean enableAutoCommit;
    @Value("${spring.kafka.one.consumer.auto-offset-reset}")
    private String autoOffsetReset;
    @Value("${spring.kafka.one.consumer.auto-commit-interval}")
    private Integer autoCommitInterval;
    @Value("${spring.kafka.one.consumer.max-poll-records}")
    private Integer maxPollRecords;

    @Bean
    public KafkaTemplate<String, String> kafkaOneTemplate() {
    
    
        return new KafkaTemplate<>(producerFactory());
    }

    @Bean
    KafkaListenerContainerFactory<ConcurrentMessageListenerContainer<Integer, String>> kafkaOneContainerFactory() {
    
    
        ConcurrentKafkaListenerContainerFactory<Integer, String> factory = new ConcurrentKafkaListenerContainerFactory<>();
        factory.setConsumerFactory(consumerFactory());
        factory.setConcurrency(3);
        factory.setBatchListener(true);
        factory.getContainerProperties().setPollTimeout(3000);
        return factory;
    }

    private ProducerFactory<String, String> producerFactory() {
    
    
        return new DefaultKafkaProducerFactory<>(producerConfigs());
    }

    public ConsumerFactory<Integer, String> consumerFactory() {
    
    
        return new DefaultKafkaConsumerFactory<>(consumerConfigs());
    }

    private Map<String, Object> producerConfigs() {
    
    
        Map<String, Object> props = new HashMap<>();
        props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
        props.put(ProducerConfig.RETRIES_CONFIG,0);
        props.put(ProducerConfig.ACKS_CONFIG,"1");
        props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
        props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
        return props;
    }

    private Map<String, Object> consumerConfigs() {
    
    
        Map<String, Object> props = new HashMap<>();
        props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
        props.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, enableAutoCommit);
        props.put(ConsumerConfig.GROUP_ID_CONFIG,groupId);
        props.put(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, autoCommitInterval);
        props.put(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG,autoOffsetReset);
        props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
        props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
        return props;
    }
}

kafka two的配置

/**
 * @author code
 * @version 1.0
 * @Date 2022/6/22 14:16
 * @Description ${kafka-two}
 */
@EnableKafka
@Configuration
public class KafkaConfigTwo {
    
    

    @Value("${spring.kafka.two.bootstrap-servers}")
    private String bootstrapServers;
    @Value("${spring.kafka.two.consumer.group-id}")
    private String groupId;
    @Value("${spring.kafka.two.consumer.enable-auto-commit}")
    private boolean enableAutoCommit;
    @Value("${spring.kafka.two.consumer.auto-offset-reset}")
    private String autoOffsetReset;
    @Value("${spring.kafka.two.consumer.auto-commit-interval}")
    private Integer autoCommitInterval;
    @Value("${spring.kafka.two.consumer.max-poll-records}")
    private Integer maxPollRecords;

    @Bean
    public KafkaTemplate<String, String> kafkaTwoTemplate() {
    
    
        return new KafkaTemplate<>(producerFactory());
    }

    @Bean
    KafkaListenerContainerFactory<ConcurrentMessageListenerContainer<Integer, String>> kafkaTwoContainerFactory() {
    
    
        ConcurrentKafkaListenerContainerFactory<Integer, String> factory = new ConcurrentKafkaListenerContainerFactory<>();
        factory.setConsumerFactory(consumerFactory());
        factory.setConcurrency(3);
        factory.setBatchListener(true);
        factory.getContainerProperties().setPollTimeout(3000);
        return factory;
    }

    private ProducerFactory<String, String> producerFactory() {
    
    
        return new DefaultKafkaProducerFactory<>(producerConfigs());
    }

    public ConsumerFactory<Integer, String> consumerFactory() {
    
    
        return new DefaultKafkaConsumerFactory<>(consumerConfigs());
    }

    private Map<String, Object> producerConfigs() {
    
    
        Map<String, Object> props = new HashMap<>();
        props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
        props.put(ProducerConfig.RETRIES_CONFIG,0);
        props.put(ProducerConfig.ACKS_CONFIG,"1");
        props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
        props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
        return props;
    }

    private Map<String, Object> consumerConfigs() {
    
    
        Map<String, Object> props = new HashMap<>();
        props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
        props.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, enableAutoCommit);
        props.put(ConsumerConfig.GROUP_ID_CONFIG,groupId);
        props.put(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, autoCommitInterval);
        props.put(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG,autoOffsetReset);
        props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
        props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
        return props;
    }
}

4、监听消息,指定kafka factory

@KafkaListener(topics = "topic",containerFactory = "kafkaOneContainerFactory")

5、主题配置在配置文件

kafka.topic=topic

@KafkaListener(topics = "#{'${kafka.topic}'.split(',')}",containerFactory = "kafkaOneContainerFactory")

6、发消息,指定kafkaTemplate

  @Autowired
    KafkaTemplate kafkaOneTemplate;

猜你喜欢

转载自blog.csdn.net/yy1209357299/article/details/125429236