成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

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

開發 項目管理
一些 CircuitBreaker 實現,如Resilience4JCircuitBreaker,在每次調用CircuitBreaker#run時調用自定義方法。它可能是低效的。在這種情況下,你可以使用CircuitBreaker#once方法。

環境:SpringBoot2.4.12 + Spring Cloud Hoxton.SR12

簡介

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

Spring Cloud支持以下斷路器實現:

  • Resilience4J
  • Sentinel
  • Spring Retry

阻塞式應用

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

<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應用

@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是唯一標識,下面你會看到為這id配置
    return cbFactory.create("remoteUser").run(() -> rest.getForObject("/100", Users.class), throwable -> "用戶用戶信息失敗");
  }


}

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

反應式應用

如果Project Reactor位于類路徑上,你還可以為響應式代碼使用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<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時被調用。

配置

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

// 對斷路器工廠進行自定義
@Component
public 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());
  }
  
}

有關如何自定義給定實現的詳細信息,請參閱以下文檔:

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 實現,如Resilience4JCircuitBreaker,在每次調用CircuitBreaker#run時調用自定義方法。它可能是低效的。在這種情況下,你可以使用CircuitBreaker#once方法。

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

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

完畢?。?!

責任編輯:武曉燕 來源: Spring全家桶實戰案例源碼
相關推薦

2022-11-04 14:13:54

2009-08-05 15:26:23

需求分析

2017-12-29 10:14:48

IT項目

2023-04-13 15:46:16

PoE供電PoE設備

2018-12-17 09:42:44

2022-09-21 14:07:56

OT安全物聯網

2020-08-26 10:42:15

IIoT智能工廠工業物聯網

2023-11-02 00:16:26

2023-09-08 16:28:13

2010-07-30 16:28:06

2023-10-24 11:07:57

2020-12-15 18:58:39

谷歌打分項目

2021-12-20 11:02:13

勒索軟件攻擊網絡安全

2022-08-26 15:54:34

云原生Kubernetes物聯網

2023-05-24 16:08:45

深度學習工業4.0

2023-02-10 10:58:41

智慧城市數據隱私

2021-12-08 14:02:46

小數據機器學習人工智能

2020-09-22 16:26:46

云計算

2009-03-24 09:05:54

資源管理IT管理廣通信達

2018-10-11 09:05:08

物聯網投資回報期IoT
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一级毛片免费看 | 亚洲成人一级 | 日韩一区二区在线看 | 免费亚洲视频 | 在线一区| 狼人伊人影院 | 国产精品久久国产精品 | 在线日韩欧美 | 欧美色图综合网 | 久久中文字幕一区 | 午夜精品久久久久久久99黑人 | 51ⅴ精品国产91久久久久久 | 国产91久久久久久 | 国产综合欧美 | 超碰精品在线 | 精品成人69xx.xyz | 国产精品成av人在线视午夜片 | 亚洲精品久久久久中文字幕欢迎你 | 激情欧美一区二区三区中文字幕 | 亚洲精品久久久久久下一站 | а天堂中文最新一区二区三区 | 一级黄色毛片a | 青青草精品 | 亚洲视频一区 | 国产美女永久免费无遮挡 | 丁香一区二区 | 精品中文字幕视频 | 欧美久久久网站 | 九九热精品在线 | 国产成人精品一区二 | 精品国产一区二区三区久久 | 毛片在线免费播放 | 亚洲一二三区精品 | 国产伊人久久久 | 精品视频一区二区三区在线观看 | 九七午夜剧场福利写真 | 欧美一区二区三区大片 | 一区免费 | 久久亚洲国产 | 九九久久精品 | 亚洲精品久久久久久久久久久久久 |