日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
斷路器在項目中的重要性:保護遠(yuǎn)程接口調(diào)用的穩(wěn)定運行

環(huán)境:SpringBoot2.4.12 + Spring Cloud Hoxton.SR12

10年的涉縣網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。成都營銷網(wǎng)站建設(shè)的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整涉縣建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“涉縣網(wǎng)站設(shè)計”,“涉縣網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。

簡介

Spring Cloud 斷路器提供了不同斷路器實現(xiàn)之間的抽象。它提供了在應(yīng)用程序中使用的一致API,讓開發(fā)人員選擇最適合應(yīng)用程序需求的斷路器實現(xiàn)。

Spring Cloud支持以下斷路器實現(xiàn):

  • Resilience4J
  • Sentinel
  • Spring Retry

阻塞式應(yīng)用

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


  org.springframework.cloud
  spring-cloud-starter-circuitbreaker-resilience4j
或者(反應(yīng)式)

  org.springframework.cloud
  spring-cloud-starter-circuitbreaker-reactor-resilience4j

簡單API應(yīng)用

@Service
public 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。如果你不想提供一個回退,你可以選擇排除它。

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

如果Project Reactor位于類路徑上,你還可以為響應(yīng)式代碼使用ReactiveCircuitBreakerFactory。下面的例子展示了如何做到這一點:

@Service
public static class DemoControllerService {
    private ReactiveCircuitBreakerFactory cbFactory;
    private WebClient webClient;




    public DemoControllerService(WebClient webClient, ReactiveCircuitBreakerFactory cbFactory) {
        this.webClient = webClient;
        this.cbFactory = cbFactory;
    }


    public Mono 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)用。

配置

你可以通過創(chuàng)建Customizer類型的bean來配置斷路器工廠。Customizer接口有一個方法(稱為customize)

// 對斷路器工廠進行自定義
@Component
public class PackCircuitBreakerCustomizer implements Customizer {


  @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());
  }
  
}

有關(guān)如何自定義給定實現(xiàn)的詳細(xì)信息,請參閱以下文檔:

Resilience4J:

https://docs.spring.io/spring-cloud-commons/spring-cloud-circuitbreaker/current/reference/html/spring-cloud-circuitbreaker.html#configuring-resilience4j-circuit-breakers

Sentinel:

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-breakers

Spring Retry:

https://docs.spring.io/spring-cloud-circuitbreaker/docs/current/reference/html/spring-cloud-circuitbreaker.html#configuring-spring-retry-circuit-breakers

一些 CircuitBreaker 實現(xiàn),如Resilience4JCircuitBreaker,在每次調(diào)用CircuitBreaker#run時調(diào)用自定義方法。它可能是低效的。在這種情況下,你可以使用CircuitBreaker#once方法。

下面的例子展示了io.github.resilience4j.circuitbreaker.CircuitBreaker的方法。斷路器消耗事件。

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

完畢!??!


網(wǎng)頁名稱:斷路器在項目中的重要性:保護遠(yuǎn)程接口調(diào)用的穩(wěn)定運行
標(biāo)題鏈接:http://www.5511xx.com/article/djsheje.html