日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

本文介紹了是否有適用于Spring Boot Kafka客戶端的斷路器?的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

如果Kafka服務器(暫時)關閉,我的Spring Boot應用程序ReactiveKafkaConsumerTemplate一直嘗試連接不成功,從而造成不必要的流量和日志文件混亂:

2021-11-10 14:45:30.265  WARN 24984 --- [onsumer-group-1] org.apache.kafka.clients.NetworkClient   : [Consumer clientId=consumer-group-1, groupId=consumer-group] Connection to node -1 (localhost/127.0.0.1:29092) could not be established. Broker may not be available.
2021-11-10 14:45:32.792  WARN 24984 --- [onsumer-group-1] org.apache.kafka.clients.NetworkClient   : [Consumer clientId=consumer-group-1, groupId=consumer-group] Bootstrap broker localhost:29092 (id: -1 rack: null) disconnected
2021-11-10 14:45:34.845  WARN 24984 --- [onsumer-group-1] org.apache.kafka.clients.NetworkClient   : [Consumer clientId=consumer-group-1, groupId=consumer-group] Connection to node -1 (localhost/127.0.0.1:29092) could not be established. Broker may not be available.
2021-11-10 14:45:34.845  WARN 24984 --- [onsumer-group-1] org.apache.kafka.clients.NetworkClient   : [Consumer clientId=consumer-group-1, groupId=consumer-group] Bootstrap broker localhost:29092 (id: -1 rack: null) disconnected

是否可以使用斷路器(靈感here或here)之類的東西,以便Spring BootKafka客戶端在出現故障時(或者更好的是連續幾次故障)放慢嘗試連接的速度,只有在服務器重新啟動后才會恢復到正常速度?

是否已有現成的配置參數或任何其他解決方案?

我知道parameterreconnect.backoff.ms,這是我創建ReactiveKafkaConsumerTemplateBean的方式:

@Bean
public ReactiveKafkaConsumerTemplate<String, MyEvent> kafkaConsumer(KafkaProperties properties) {
    final Map<String, Object> map = new HashMap<>(properties.buildConsumerProperties());
    map.put(ConsumerConfig.GROUP_ID_CONFIG, "MyGroup");
    map.put(ConsumerConfig.RECONNECT_BACKOFF_MS_CONFIG, 10_000L);
    final JsonDeserializer<DisplayCurrencyEvent> jsonDeserializer = new JsonDeserializer<>();
    jsonDeserializer.addTrustedPackages("com.example.myapplication");

    return new ReactiveKafkaConsumerTemplate<>(
            ReceiverOptions
                    .<String, MyEvent>create(map)
                    .withKeyDeserializer(new ErrorHandlingDeserializer<>(new StringDeserializer()))
                    .withValueDeserializer(new ErrorHandlingDeserializer<>(jsonDeserializer))
                    .subscription(List.of("MyTopic")));
}

消費者仍嘗試每3秒連接一次。

推薦答案

參見https://kafka.apache.org/documentation/#consumerconfigs_retry.backoff.ms

嘗試重新連接到給定主機之前等待的基本時間。這避免了在緊密環路中重復連接到主機。此退避適用于客戶端到代理的所有連接嘗試。

和https://kafka.apache.org/documentation/#consumerconfigs_reconnect.backoff.max.ms

重新連接到多次連接失敗的代理時等待的最長時間(以毫秒為單位)。如果提供,則每次連續連接失敗時,每臺主機的退避將呈指數級增加,最高可達此最大值。計算退避增加后,增加20%的隨機抖動以避免連接風暴。

這篇關于是否有適用于Spring Boot Kafka客戶端的斷路器?的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,

分享到:
標簽:Boot Kafka Spring 客戶端 斷路器 適用于
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定