spring 整合kafka監(jiān)聽(tīng)消費(fèi)的配置過(guò)程
最近項(xiàng)目里有個(gè)需求,要消費(fèi)kafka里的數(shù)據(jù)。之前也手動(dòng)寫(xiě)過(guò)代碼去消費(fèi)kafka數(shù)據(jù)。但是轉(zhuǎn)念一想。既然spring提供了消費(fèi)kafka的方法。就沒(méi)必要再去重復(fù)造輪子。于是嘗試使用spring的API。
項(xiàng)目技術(shù)背景,使用springMVC,XML配置和注解相互使用。kafka的配置都是使用XML方式。
整合過(guò)程1. 引入spring-kafka的依賴(lài)包
<dependency> <groupId>org.springframework.kafka</groupId> <artifactId>spring-kafka</artifactId> <version>2.2.0.RELEASE</version> </dependency>
2. 在spring的xml文件里增加配置項(xiàng),也可以單獨(dú)創(chuàng)建一個(gè)spring-context-XX.xml文件。
<!-- consumer configuration 該配置項(xiàng)可以根據(jù)自己業(yè)務(wù)的實(shí)際需求做增加或刪除--> <bean class='java.util.HashMap'> <constructor-arg> <map><entry key='bootstrap.servers' value='${kafka.bootstrap.servers}' /><entry key='group.id' value='group' /><entry key='enable.auto.commit' value='true' /><entry key='auto.commit.interval.ms' value='3000' /><entry key='session.timeout.ms' value='10000' /><entry key='key.deserializer' value='org.apache.kafka.common.serialization.StringDeserializer' /><entry key='value.deserializer' value='org.apache.kafka.common.serialization.StringDeserializer' /> </map> </constructor-arg> </bean> <!-- create factory 該類(lèi)是spring jar包里提供,就這么配置--> <bean class='org.springframework.kafka.core.DefaultKafkaConsumerFactory'> <constructor-arg> <ref bean='consumerProperties' /> </constructor-arg> </bean> <!-- 自定義的消費(fèi)類(lèi),需要實(shí)現(xiàn)spring的接口 --> <bean /> <!-- 該類(lèi)也是jar包里提供的,注入的監(jiān)聽(tīng)類(lèi)是自己定義的,topic名稱(chēng)是配置文件引入的--> <bean class='org.springframework.kafka.listener.ContainerProperties'> <constructor-arg name='topics' value='${kafka.paypal.topic.name}'/> <property name='messageListener' ref='payPalConsumer' /> </bean> <!-- 改類(lèi)也是jar里提供的,把這個(gè)containerProperties和consumerfactory 注入 --> <bean init-method='doStart'> <constructor-arg ref='consumerFactory' /> <constructor-arg ref='containerProperties' /> </bean>
2. 自定義消費(fèi)者類(lèi),消費(fèi)者類(lèi)依然可以使用注解。
/** * get msg from kafka */@Component public class PayPalConsumer implements MessageListener<String, String> { private static Logger logger = LoggerFactory.getLogger(PayPalConsumer.class); @Autowired private XXService XXService; @Override public void onMessage(ConsumerRecord<String, String> authorizeRecord) { String value = authorizeRecord.value(); if (StringUtils.isEmpty(value)){ logger.warn('receive message from kafka is null'); return; } logger.info('receive message from kafka is {}',value); }}
使用這個(gè)步驟配置,一次性過(guò)。非常順利。
到此這篇關(guān)于spring 整合kafka監(jiān)聽(tīng)消費(fèi)的配置過(guò)程的文章就介紹到這了,更多相關(guān)spring 整合kafka內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 詳解盒子端CSS動(dòng)畫(huà)性能提升2. CSS hack用法案例詳解3. PHP字符串前后字符或空格刪除方法介紹4. 使用HttpClient消費(fèi)ASP.NET Web API服務(wù)案例5. Jsp+Servlet實(shí)現(xiàn)文件上傳下載 刪除上傳文件(三)6. ASP.NET Core實(shí)現(xiàn)中間件的幾種方式7. input submit、button和回車(chē)鍵提交數(shù)據(jù)詳解8. ASP常用日期格式化函數(shù) FormatDate()9. 詳解瀏覽器的緩存機(jī)制10. JSP servlet實(shí)現(xiàn)文件上傳下載和刪除
