91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在spring中使用kafka對消費者進行監聽

發布時間:2021-03-05 14:36:31 來源:億速云 閱讀:554 作者:Leah 欄目:開發技術

這期內容當中小編將會給大家帶來有關如何在spring中使用kafka對消費者進行監聽,文章內容豐富且以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

整合過程

1. 引入spring-kafka的依賴包

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

2. 在spring的xml文件里增加配置項,也可以單獨創建一個spring-context-XX.xml文件。

<!-- consumer configuration 該配置項可以根據自己業務的實際需求做增加或刪除-->
  <bean id="consumerProperties" 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 該類是spring jar包里提供,就這么配置-->
  <bean id="consumerFactory" class="org.springframework.kafka.core.DefaultKafkaConsumerFactory">
    <constructor-arg>
      <ref bean="consumerProperties" />
    </constructor-arg>
  </bean>

  <!-- 自定義的消費類,需要實現spring的接口 -->
  <bean id="payPalConsumer"
     class="com.chao.service.consumer.PayPalConsumer" />

  <!-- 該類也是jar包里提供的,注入的監聽類是自己定義的,topic名稱是配置文件引入的-->
  <bean id="containerProperties" class="org.springframework.kafka.listener.ContainerProperties">
    <constructor-arg name="topics" value="${kafka.paypal.topic.name}"/>
    <property name="messageListener" ref="payPalConsumer" />
  </bean>

  <!-- 改類也是jar里提供的,把這個containerProperties和consumerfactory 注入 -->
  <bean id="messageListenerContainer" class="org.springframework.kafka.listener.KafkaMessageListenerContainer"
     init-method="doStart">
    <constructor-arg ref="consumerFactory" />
    <constructor-arg ref="containerProperties" />
  </bean>

2. 自定義消費者類,消費者類依然可以使用注解。

/**
 * 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);
  }
}

上述就是小編為大家分享的如何在spring中使用kafka對消費者進行監聽了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

星子县| 恩平市| 大兴区| 灵川县| 涟源市| 靖江市| 瑞丽市| 临高县| 遂昌县| 翁源县| 梁平县| 岑巩县| 黄龙县| 山丹县| 荥经县| 会昌县| 浑源县| 富顺县| 磐石市| 定边县| 榆树市| 贵阳市| 连江县| 玉门市| 新绛县| 珠海市| 永清县| 怀集县| 奉节县| 宁陕县| 南郑县| 内丘县| 安吉县| 沂水县| 方城县| 昔阳县| 大宁县| 通榆县| 泰兴市| 凌源市| 高雄市|