SpringBoot實現(xiàn)kafka多源配置的示例代碼
更新時間:2024年06月06日 10:42:53 作者:it噩夢
實際開發(fā)中,不同的topic可能來自不同的集群,所以就需要配置不同的kafka數(shù)據(jù)源,基于springboot自動配置的思想,最終通過配置文件的配置,自動生成生產者及消費者的配置,本文介紹了SpringBoot實現(xiàn)kafka多源配置,需要的朋友可以參考下
背景
實際開發(fā)中,不同的topic可能來自不同的集群,所以就需要配置不同的kafka數(shù)據(jù)源,基于springboot自動配置的思想,最終通過配置文件的配置,自動生成生產者及消費者的配置。
核心配置
自動化配置類
import com.example.kafka.autoconfig.CustomKafkaDataSourceRegister; import com.example.kafka.autoconfig.kafkaConsumerConfig; import org.springframework.beans.BeansException; import org.springframework.beans.factory.BeanFactory; import org.springframework.beans.factory.BeanFactoryAware; import org.springframework.beans.factory.config.SmartInstantiationAwareBeanPostProcessor; import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication; import org.springframework.boot.context.properties.EnableConfigurationProperties; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Import; import org.springframework.kafka.annotation.EnableKafka; @EnableKafka @Configuration( proxyBeanMethods = false ) @ConditionalOnWebApplication @EnableConfigurationProperties({kafkaConsumerConfig.class}) @Import({CustomKafkaDataSourceRegister.class}) public class MyKafkaAutoConfiguration implements BeanFactoryAware, SmartInstantiationAwareBeanPostProcessor { public MyKafkaAutoConfiguration() { } public void setBeanFactory(BeanFactory beanFactory) throws BeansException { beanFactory.getBean(CustomKafkaDataSourceRegister.class); } }
注冊生產者、消費者核心bean到spring
public void afterPropertiesSet() { Map<String, ConsumerConfigWrapper> factories = kafkaConsumerConfig.getFactories(); if (factories != null && !factories.isEmpty()) { factories.forEach((factoryName, consumerConfig) -> { KafkaProperties.Listener listener = consumerConfig.getListener(); Integer concurrency = consumerConfig.getConcurrency(); // 創(chuàng)建監(jiān)聽容器工廠 ConcurrentKafkaListenerContainerFactory<String, String> containerFactory = createKafkaListenerContainerFactory(consumerConfig.buildProperties(), listener, concurrency); // 注冊到容器 if (!beanFactory.containsBean(factoryName)) { beanFactory.registerSingleton(factoryName, containerFactory); } }); } Map<String, KafkaProperties.Producer> templates = kafkaProducerConfig.getTemplates(); if (!ObjectUtils.isEmpty(templates)) { templates.forEach((templateName, producerConfig) -> { //registerBean(beanFactory, templateName, KafkaTemplate.class, propertyValues); //注冊spring bean的兩種方式 registerBeanWithConstructor(beanFactory, templateName, KafkaTemplate.class, producerFactoryValues(producerConfig.buildProperties())); }); } }
配置spring.factories
org.springframework.boot.autoconfigure.EnableAutoConfiguration=\ com.example.kafka.MyKafkaAutoConfiguration
yml配置
spring: kafka: multiple: consumer: factories: test-factory: key-deserializer: org.apache.kafka.common.serialization.StringDeserializer value-deserializer: org.apache.kafka.common.serialization.StringDeserializer bootstrap-servers: 192.168.56.112:9092 group-id: group_a concurrency: 25 fetch-min-size: 1048576 fetch-max-wait: 3000 listener: type: batch properties: spring-json-trusted-packages: '*' key-deserializer: org.apache.kafka.common.serialization.StringDeserializer value-deserializer: org.apache.kafka.common.serialization.StringDeserializer auto-offset-reset: latest producer: templates: test-template: bootstrap-servers: 192.168.56.112:9092 key-serializer: org.apache.kafka.common.serialization.StringSerializer value-serializer: org.apache.kafka.common.serialization.StringSerializer key-serializer: org.apache.kafka.common.serialization.StringSerializer value-serializer: org.apache.kafka.common.serialization.StringSerializer
使用
到此這篇關于SpringBoot實現(xiàn)kafka多源配置的示例代碼的文章就介紹到這了,更多相關SpringBoot kafka多源配置內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Mybatis返回單個實體或者返回List的實現(xiàn)
這篇文章主要介紹了Mybatis返回單個實體或者返回List的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07SpringBoot如何根據(jù)目錄路徑生成接口的url路徑
這篇文章主要介紹了SpringBoot如何根據(jù)目錄路徑生成接口的url路徑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-11-11