日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

斷路器在項目中的重要性:保護遠程接口調用的穩定運行

來源: 責編: 時間:2023-11-06 08:52:52 246觀看
導讀環境:SpringBoot2.4.12 + Spring Cloud Hoxton.SR12簡介Spring Cloud 斷路器提供了不同斷路器實現之間的抽象。它提供了在應用程序中使用的一致API,讓開發人員選擇最適合應用程序需求的斷路器實現。Spring Cloud支持以

環境:SpringBoot2.4.12 + Spring Cloud Hoxton.SR12T6128資訊網——每日最新資訊28at.com

簡介

Spring Cloud 斷路器提供了不同斷路器實現之間的抽象。它提供了在應用程序中使用的一致API,讓開發人員選擇最適合應用程序需求的斷路器實現。T6128資訊網——每日最新資訊28at.com

Spring Cloud支持以下斷路器實現:T6128資訊網——每日最新資訊28at.com

  • Resilience4J
  • Sentinel
  • Spring Retry

阻塞式應用

要在代碼中創建斷路器,可以使用CircuitBreakerFactory API。當你在類路徑中包含Spring Cloud Circuit Breaker starter時,將自動為你創建實現此API的bean。下面的例子展示了如何使用這個API的一個簡單例子:T6128資訊網——每日最新資訊28at.com

<dependency>  <groupId>org.springframework.cloud</groupId>  <artifactId>spring-cloud-starter-circuitbreaker-resilience4j</artifactId></dependency>
或者(反應式)
<dependency>  <groupId>org.springframework.cloud</groupId>  <artifactId>spring-cloud-starter-circuitbreaker-reactor-resilience4j</artifactId></dependency>

簡單API應用T6128資訊網——每日最新資訊28at.com

@Servicepublic static class UsersService {  private RestTemplate rest;  private CircuitBreakerFactory cbFactory;  public DemoControllerService(RestTemplate rest, CircuitBreakerFactory cbFactory) {    this.rest = rest;    this.cbFactory = cbFactory;  }  public Users getUser() {    // 這里remoteUser是唯一標識,下面你會看到為這id配置    return cbFactory.create("remoteUser").run(() -> rest.getForObject("/100", Users.class), throwable -> "用戶用戶信息失敗");  }}

CircuitBreakerFactory.create API創建一個名為CircuitBreaker的類實例。run方法接受一個Supplier和一個Function。Supplier是你要包裝在斷路器中的代碼。Function是在斷路器跳閘時運行的后備功能。Function被傳遞導致觸發回退的Throwable。如果你不想提供一個回退,你可以選擇排除它。T6128資訊網——每日最新資訊28at.com

反應式應用

如果Project Reactor位于類路徑上,你還可以為響應式代碼使用ReactiveCircuitBreakerFactory。下面的例子展示了如何做到這一點:T6128資訊網——每日最新資訊28at.com

@Servicepublic static class DemoControllerService {    private ReactiveCircuitBreakerFactory cbFactory;    private WebClient webClient;    public DemoControllerService(WebClient webClient, ReactiveCircuitBreakerFactory cbFactory) {        this.webClient = webClient;        this.cbFactory = cbFactory;    }    public Mono<Users> getUser() {        return webClient.get().uri("/100").retrieve().bodyToMono(Users.class).transform(        it -> cbFactory.create("remoteUser").run(it, throwable -> return Mono.just("獲取用戶失敗")));    }}

ReactiveCircuitBreakerFactory.create API創建一個名為ReactiveCircuitBreaker的類實例。run方法將一個Mono或Flux包在一個斷路器中。你可以選擇配置一個回退函數,該函數將在斷路器被觸發并傳遞導致故障的Throwable時被調用。T6128資訊網——每日最新資訊28at.com

配置

你可以通過創建Customizer類型的bean來配置斷路器工廠。Customizer接口有一個方法(稱為customize)T6128資訊網——每日最新資訊28at.com

// 對斷路器工廠進行自定義@Componentpublic class PackCircuitBreakerCustomizer implements Customizer<Resilience4JCircuitBreakerFactory> {  @Override  public void customize(Resilience4JCircuitBreakerFactory tocustomize) {    tocustomize.configure(builder -> {      // 配置超時      builder.timeLimiterConfig(          TimeLimiterConfig.custom()          .timeoutDuration(Duration.ofMillis(3000))          .build()      ) ;      // 配置熔斷      builder.circuitBreakerConfig(          CircuitBreakerConfig.custom()          .failureRateThreshold(0.1f) // 當故障率大于等于故障閾值時,斷路器切換到開路狀態,開始短路調用。          .minimumNumberOfCalls(3) // 斷路器打開的前提是至少有3次的調用          .build()      ) ;    }, "a1", "a2", "a3", "remoteUser") ;// 這里指定了只有哪些id都會被應用這些配置    // 為所有的斷路器提供默認配置    tocustomize.configureDefault(id -> new Resilience4JConfigBuilder(id)        .circuitBreakerConfig(CircuitBreakerConfig.ofDefaults())        .timeLimiterConfig(TimeLimiterConfig.ofDefaults()).build());  }  }

T6128資訊網——每日最新資訊28at.com

有關如何自定義給定實現的詳細信息,請參閱以下文檔:T6128資訊網——每日最新資訊28at.com

Resilience4J:T6128資訊網——每日最新資訊28at.com

https://docs.spring.io/spring-cloud-commons/spring-cloud-circuitbreaker/current/reference/html/spring-cloud-circuitbreaker.html#configuring-resilience4j-circuit-breakersT6128資訊網——每日最新資訊28at.com

Sentinel:T6128資訊網——每日最新資訊28at.com

https://github.com/alibaba/spring-cloud-alibaba/blob/2.2.x/spring-cloud-alibaba-docs/src/main/asciidoc/circuitbreaker-sentinel.adoc#circuit-breaker-spring-cloud-circuit-breaker-with-sentinel%E2%80%94%E2%80%8Bconfiguring-sentinel-circuit-breakersT6128資訊網——每日最新資訊28at.com

Spring Retry:T6128資訊網——每日最新資訊28at.com

https://docs.spring.io/spring-cloud-circuitbreaker/docs/current/reference/html/spring-cloud-circuitbreaker.html#configuring-spring-retry-circuit-breakersT6128資訊網——每日最新資訊28at.com

一些 CircuitBreaker 實現,如Resilience4JCircuitBreaker,在每次調用CircuitBreaker#run時調用自定義方法。它可能是低效的。在這種情況下,你可以使用CircuitBreaker#once方法。T6128資訊網——每日最新資訊28at.com

下面的例子展示了io.github.resilience4j.circuitbreaker.CircuitBreaker的方法。斷路器消耗事件。T6128資訊網——每日最新資訊28at.com

Customizer.once(circuitBreaker -> {  circuitBreaker.getEventPublisher()    .onStateTransition(event -> log.info("{}: {}", event.getCircuitBreakerName(), event.getStateTransition()));}, CircuitBreaker::getName)

完畢!!!T6128資訊網——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-17158-0.html斷路器在項目中的重要性:保護遠程接口調用的穩定運行

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 聊聊Spring 微服務和多租戶

下一篇: AIDL在Android應用程序中的重要作用

標簽:
  • 熱門焦點
  • Redmi Pad評測:紅米充滿野心的一次嘗試

    從Note系列到K系列,從藍牙耳機到筆記本電腦,紅米不知不覺之間也已經形成了自己頗有競爭力的產品體系,在中端和次旗艦市場上甚至要比小米新機的表現來得更好,正所謂“大丈夫生居
  • 把LangChain跑起來的三個方法

    使用LangChain開發LLM應用時,需要機器進行GLM部署,好多同學第一步就被勸退了,那么如何繞過這個步驟先學習LLM模型的應用,對Langchain進行快速上手?本片講解3個把LangChain跑起來
  • 學習JavaScript的10個理由...

    作者 | Simplilearn編譯 | 王瑞平當你決心學習一門語言的時候,很難選擇到底應該學習哪一門,常用的語言有Python、Java、JavaScript、C/CPP、PHP、Swift、C#、Ruby、Objective-
  • 三分鐘白話RocketMQ系列—— 如何發送消息

    我們知道RocketMQ主要分為消息 生產、存儲(消息堆積)、消費 三大塊領域。那接下來,我們白話一下,RocketMQ是如何發送消息的,揭秘消息生產全過程。注意,如果白話中不小心提到相關代
  • Temu起訴SHEIN,跨境電商戰事升級

    來源 | 伯虎財經(bohuFN)作者 | 陳平安日前據外媒報道,拼多多旗下跨境電商平臺Temu正對競爭對手SHEIN提起新訴訟,訴狀稱Shein&ldquo;利用市場支配力量強迫服裝廠商與之簽訂獨家
  • 電視息屏休眠仍有網絡上傳 愛奇藝被質疑“薅消費者羊毛”

    記者丨寧曉敏 見習生丨汗青出品丨鰲頭財經(theSankei) 前不久,愛奇藝發布了一份亮眼的一季報,不僅營收和會員營收創造歷史最佳表現,其運營利潤也連續6個月實現增長。自去年年初
  • 華為發布HarmonyOS 4:更好玩、更流暢、更安全

    在8月4日的華為開發者大會2023(HDC.Together)大會上,HarmonyOS 4正式發布。自2019年發布以來,HarmonyOS一直以用戶為中心,經歷四年多的發展HarmonyOS已
  • 2納米決戰2025

    集微網報道 從三強爭霸到四雄逐鹿,2nm的廝殺聲已然隱約傳來。無論是老牌勁旅臺積電、三星,還是誓言重回先進制程領先地位的英特爾,甚至初成立不久的新
  • 2299元起!iQOO Pad明晚首銷:性能最強天璣平板

    5月23日,iQOO如期舉行了新品發布會,除了首發安卓最強旗艦處理器的iQOO Neo8系列新機外,還在發布會上推出了旗下首款平板電腦——iQOO Pad,其最大的賣點
Top 主站蜘蛛池模板: 榆社县| 石河子市| 鄄城县| 边坝县| 贺州市| 虞城县| 湘潭县| 荆门市| 登封市| 昆山市| 金堂县| 磴口县| 田阳县| 大厂| 凤阳县| 新田县| 合川市| 玉门市| 郁南县| 丁青县| 剑河县| 图们市| 越西县| 永川市| 秭归县| 焦作市| 桐乡市| 太康县| 郴州市| 衡水市| 盐池县| 沾益县| 东丰县| 伊宁市| 五指山市| 祁阳县| 永胜县| 北安市| 水富县| 庆城县| 嘉兴市|