AVt天堂网 手机版,亚洲va久久久噜噜噜久久4399,天天综合亚洲色在线精品,亚洲一级Av无码毛片久久精品

當(dāng)前位置:首頁 > 科技  > 軟件

斷路器在項目中的重要性:保護(hù)遠(yuǎn)程接口調(diào)用的穩(wěn)定運行

來源: 責(zé)編: 時間:2023-11-06 08:52:52 268觀看
導(dǎo)讀環(huán)境:SpringBoot2.4.12 + Spring Cloud Hoxton.SR12簡介Spring Cloud 斷路器提供了不同斷路器實現(xiàn)之間的抽象。它提供了在應(yīng)用程序中使用的一致API,讓開發(fā)人員選擇最適合應(yīng)用程序需求的斷路器實現(xiàn)。Spring Cloud支持以

環(huán)境:SpringBoot2.4.12 + Spring Cloud Hoxton.SR12IcV28資訊網(wǎng)——每日最新資訊28at.com

簡介

Spring Cloud 斷路器提供了不同斷路器實現(xiàn)之間的抽象。它提供了在應(yīng)用程序中使用的一致API,讓開發(fā)人員選擇最適合應(yīng)用程序需求的斷路器實現(xiàn)。IcV28資訊網(wǎng)——每日最新資訊28at.com

Spring Cloud支持以下斷路器實現(xiàn):IcV28資訊網(wǎng)——每日最新資訊28at.com

  • Resilience4J
  • Sentinel
  • Spring Retry

阻塞式應(yīng)用

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

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

簡單API應(yīng)用IcV28資訊網(wǎng)——每日最新資訊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是唯一標(biāo)識,下面你會看到為這id配置    return cbFactory.create("remoteUser").run(() -> rest.getForObject("/100", Users.class), throwable -> "用戶用戶信息失敗");  }}

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

反應(yīng)式應(yīng)用

如果Project Reactor位于類路徑上,你還可以為響應(yīng)式代碼使用ReactiveCircuitBreakerFactory。下面的例子展示了如何做到這一點:IcV28資訊網(wǎng)——每日最新資訊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創(chuàng)建一個名為ReactiveCircuitBreaker的類實例。run方法將一個Mono或Flux包在一個斷路器中。你可以選擇配置一個回退函數(shù),該函數(shù)將在斷路器被觸發(fā)并傳遞導(dǎo)致故障的Throwable時被調(diào)用。IcV28資訊網(wǎng)——每日最新資訊28at.com

配置

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

// 對斷路器工廠進(jìn)行自定義@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) // 當(dāng)故障率大于等于故障閾值時,斷路器切換到開路狀態(tài),開始短路調(diào)用。          .minimumNumberOfCalls(3) // 斷路器打開的前提是至少有3次的調(diào)用          .build()      ) ;    }, "a1", "a2", "a3", "remoteUser") ;// 這里指定了只有哪些id都會被應(yīng)用這些配置    // 為所有的斷路器提供默認(rèn)配置    tocustomize.configureDefault(id -> new Resilience4JConfigBuilder(id)        .circuitBreakerConfig(CircuitBreakerConfig.ofDefaults())        .timeLimiterConfig(TimeLimiterConfig.ofDefaults()).build());  }  }

IcV28資訊網(wǎng)——每日最新資訊28at.com

有關(guān)如何自定義給定實現(xiàn)的詳細(xì)信息,請參閱以下文檔:IcV28資訊網(wǎng)——每日最新資訊28at.com

Resilience4J:IcV28資訊網(wǎng)——每日最新資訊28at.com

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

Sentinel:IcV28資訊網(wǎng)——每日最新資訊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-breakersIcV28資訊網(wǎng)——每日最新資訊28at.com

Spring Retry:IcV28資訊網(wǎng)——每日最新資訊28at.com

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

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

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

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

完畢!!!IcV28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.tebozhan.com/showinfo-26-17158-0.html斷路器在項目中的重要性:保護(hù)遠(yuǎn)程接口調(diào)用的穩(wěn)定運行

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

上一篇: 聊聊Spring 微服務(wù)和多租戶

下一篇: AIDL在Android應(yīng)用程序中的重要作用

標(biāo)簽:
  • 熱門焦點
  • 服務(wù)存儲設(shè)計模式:Cache-Aside模式

    Cache-Aside模式一種常用的緩存方式,通常是把數(shù)據(jù)從主存儲加載到KV緩存中,加速后續(xù)的訪問。在存在重復(fù)度的場景,Cache-Aside可以提升服務(wù)性能,降低底層存儲的壓力,缺點是緩存和底
  • 一年經(jīng)驗在二線城市面試后端的經(jīng)驗分享

    忠告這篇文章只適合2年內(nèi)工作經(jīng)驗、甚至沒有工作經(jīng)驗的朋友閱讀。如果你是2年以上工作經(jīng)驗,請果斷劃走,對你沒啥幫助~主人公這篇文章內(nèi)容來自 「升職加薪」星球星友 的投稿,坐
  • 三言兩語說透設(shè)計模式的藝術(shù)-單例模式

    寫在前面單例模式是一種常用的軟件設(shè)計模式,它所創(chuàng)建的對象只有一個實例,且該實例易于被外界訪問。單例對象由于只有一個實例,所以它可以方便地被系統(tǒng)中的其他對象共享,從而減少
  • 讓我們一起聊聊文件的操作

    文件【1】文件是什么?文件是保存數(shù)據(jù)的地方,是數(shù)據(jù)源的一種,比如大家經(jīng)常使用的word文檔、txt文件、excel文件、jpg文件...都是文件。文件最主要的作用就是保存數(shù)據(jù),它既可以保
  • 自動化在DevOps中的力量:簡化軟件開發(fā)和交付

    自動化在DevOps中扮演著重要角色,它提升了DevOps的效能。通過自動化工具和方法,DevOps團隊可以實現(xiàn)以下目標(biāo):消除手動和重復(fù)性任務(wù)。簡化流程。在整個軟件開發(fā)生命周期中實現(xiàn)更
  • .NET 程序的 GDI 句柄泄露的再反思

    一、背景1. 講故事上個月我寫過一篇 如何洞察 C# 程序的 GDI 句柄泄露 文章,當(dāng)時用的是 GDIView + WinDbg 把問題搞定,前者用來定位泄露資源,后者用來定位泄露代碼,后面有朋友反
  • 慕巖炮轟抖音,百合網(wǎng)今何在?

    來源:價值研究所 作者:Hernanderz&ldquo;難道就因為自己的一個產(chǎn)品牛逼了,從客服到總裁,都不愿意正視自己產(chǎn)品和運營上的問題,選擇逃避了嗎?&rdquo;這一番話,出自百合網(wǎng)聯(lián)合創(chuàng)
  • 東方甄選單飛:有些鳥注定是關(guān)不住的

    文/彭寬鴻編輯/羅卿東方甄選創(chuàng)始人俞敏洪帶隊的&ldquo;7天甘肅行&rdquo;直播活動已在近日順利收官。成立后一年多時間里,東方甄選要脫離抖音自立門戶的傳聞不絕于耳,&ldquo;7
  • iQOO 11S新品發(fā)布會

    iQOO將在7月4日19:00舉行新品發(fā)布會,推出杭州亞運會電競賽事官方用機iQOO 11S。
Top