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

Resilience4j 深度揭秘:如何在 Spring Boot 中實現容錯機制

開發 架構
本文將詳細介紹如何在 Spring Boot 項目中整合 Resilience4j,使你的應用更具彈性和可靠性。

在現代微服務架構中,服務之間的調用可能會因網絡延遲、服務故障等原因導致失敗。為了解決這些問題,Resilience4j 提供了一套可靠的容錯機制。本文將詳細介紹如何在 Spring Boot 項目中整合 Resilience4j,使你的應用更具彈性和可靠性。

一、Resilience4j 簡介

什么是 Resilience4j

Resilience4j 是一個輕量級的容錯庫,專為 Java 8 及以上版本設計。它提供了一組強大的容錯機制,包括斷路器(Circuit Breaker)、限流器(Rate Limiter)、艙壁隔離(Bulkhead)、重試(Retry)和時間限制器(Time Limiter)。

主要特性

  • 斷路器(Circuit Breaker):防止一個服務的故障蔓延到整個系統。
  • 限流器(Rate Limiter):限制特定時間內的請求數量,防止過載。
  • 艙壁隔離(Bulkhead):隔離系統的不同部分,防止故障蔓延。
  • 重試(Retry):在請求失敗時自動重試。
  • 時間限制器(Time Limiter):為請求設置時間限制,防止長時間等待。

與 Hystrix 的對比

Resilience4j 旨在取代 Netflix Hystrix,提供更輕量和現代的解決方案。與 Hystrix 相比,Resilience4j 的主要優勢在于它的依賴更少、性能更好,并且完全支持 Java 8 以上的函數式編程特性。

二、環境準備

項目初始化

使用 Spring Initializr 創建一個新的 Spring Boot 項目,并添加以下依賴:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
</dependency>

<dependency>
    <groupId>io.github.resilience4j</groupId>
    <artifactId>resilience4j-spring-boot2</artifactId>
    <version>2.1.0</version>
</dependency>

三、配置 Resilience4j

基本配置

在 application.yml 文件中添加基本配置:

resilience4j:
  circuitbreaker:
    configs:
      default:
        registerHealthIndicator: true
        slidingWindowSize: 100
        minimumNumberOfCalls: 10
        failureRateThreshold: 50
        waitDurationInOpenState: 10000
        permittedNumberOfCallsInHalfOpenState: 3

配置項解釋:

  • registerHealthIndicator: 是否注冊 Circuit Breaker 的健康指標,默認為 false。設置為 true 可以通過 Actuator 端點監控 Circuit Breaker 的狀態。
  • slidingWindowSize: 滑動窗口的大小,用于計算失敗率。這里設置為 100,表示最近 100 個請求會被用來計算失敗率。
  • minimumNumberOfCalls: 在滑動窗口內,至少需要有這么多請求才能開始計算失敗率。這里設置為 10,表示至少需要 10 個請求后才會開始計算失敗率。
  • failureRateThreshold: 失敗率閾值,當失敗率超過這個值時,Circuit Breaker 會進入 OPEN 狀態。這里設置為 50,表示當失敗率超過 50% 時,Circuit Breaker 會打開。
  • waitDurationInOpenState: Circuit Breaker 處于 OPEN 狀態時的等待時間,單位毫秒。這里設置為 10000,表示 Circuit Breaker 打開后會等待 10 秒鐘。
  • permittedNumberOfCallsInHalfOpenState: Circuit Breaker 處于 HALF_OPEN 狀態時允許的請求數。這里設置為 3,表示 Circuit Breaker 半開狀態時允許 3 個請求通過。

這段配置定義了一個基本的 Circuit Breaker 行為,可以保護系統免受頻繁失敗的服務的影響。通過調整這些參數,可以根據具體應用場景來優化 Circuit Breaker 的行為。

注意: 這只是默認配置,可以在創建 Circuit Breaker 實例時覆蓋這些配置。

配置 Circuit Breaker

配置斷路器:

resilience4j:
  circuitbreaker:
    instances:
      backendA:
        registerHealthIndicator: true
        slidingWindowSize: 100
        minimumNumberOfCalls: 10
        failureRateThreshold: 50
        waitDurationInOpenState: 10000
        permittedNumberOfCallsInHalfOpenState: 3

不同于之前的默認配置,這里明確定義了一個名為 backendA 的 Circuit Breaker 實例,并為其指定了具體的配置參數。這意味著,這個配置只適用于名為 backendA 的 Circuit Breaker 實例,而其他 Circuit Breaker 實例將使用默認配置(如果存在)。

配置 Rate Limiter

配置限流器:

resilience4j:
  ratelimiter:
    instances:
      backendA:
        limitForPeriod: 10
        limitRefreshPeriod: 5000

配置項解釋:

  • limitForPeriod: 在限流周期內允許的最大請求數。這里設置為 10,表示在 5 秒內最多允許 10 個請求。
  • limitRefreshPeriod: 限流周期的持續時間,單位毫秒。這里設置為 5000,表示限流周期為 5 秒。

配置含義:

這段配置定義了一個名為 backendA 的 RateLimiter 實例,用于控制對 backendA 服務或資源的訪問速率。

(1)限流策略: Resilience4j 使用令牌桶算法實現限流。RateLimiter 會維護一個固定數量的令牌,每個令牌代表一個請求的許可。當請求到達時,RateLimiter 會嘗試獲取令牌。如果獲取成功,則允許請求繼續執行;如果獲取失敗,則請求會被拒絕或延遲處理。

(2) 限流配置: 本段配置中的 limitForPeriod 和 limitRefreshPeriod 參數定義了 RateLimiter 的限流策略。

  • limitForPeriod 規定了限流周期內允許的最大請求數。例如,本例中設置為 10,表示在 5 秒內最多允許 10 個請求。
  • limitRefreshPeriod 規定了限流周期的持續時間。例如,本例中設置為 5000,表示限流周期為 5 秒。這意味著,RateLimiter 會每隔 5 秒重新計算可用的令牌數。

限流效果:

假設 limitForPeriod 為 10,limitRefreshPeriod 為 5000。那么,在任意的 5 秒內,系統最多只會處理 10 個請求。如果在 5 秒內收到超過 10 個請求,則后面的請求會被拒絕或延遲處理。

配置 Bulkhead

配置艙壁隔離:

resilience4j:
  bulkhead:
    instances:
      backendA:
        maxConcurrentCalls: 25
        maxWaitDuration: 100

配置項解釋:

  • maxConcurrentCalls: 同時允許的最大并發調用數。這里設置為 25,表示 backendA 服務最多可以同時處理 25 個并發請求。
  • maxWaitDuration: 當并發請求超過 maxConcurrentCalls 限制時,新請求最長等待時間,單位毫秒。這里設置為 100,表示新請求最多等待 100 毫秒,如果仍然無法獲得處理資源,則會被拒絕或拋出異常。

配置含義:

這段配置定義了一個名為 backendA 的 Bulkhead 實例,用于控制對 backendA 服務或資源的并發訪問。

(1)隔離策略: Resilience4j 使用令牌桶算法實現對并發請求的隔離。Bulkhead 會維護一個固定數量的令牌,每個令牌代表一個處理資源的許可。當請求到達時,Bulkhead 會嘗試獲取令牌。如果獲取成功,則允許請求繼續執行;如果獲取失敗,則請求會被拒絕或延遲處理。

(2)并發控制: 本段配置中的 maxConcurrentCalls 和 maxWaitDuration 參數定義了 Bulkhead 的并發控制策略。

  • maxConcurrentCalls 規定了同時允許的最大并發調用數。例如,本例中設置為 25,表示 backendA 服務最多可以同時處理 25 個并發請求。
  • maxWaitDuration 規定了當并發請求超過 maxConcurrentCalls 限制時,新請求最長等待時間。例如,本例中設置為 100,表示新請求最多等待 100 毫秒,如果仍然無法獲得處理資源,則會被拒絕或拋出異常。

限流效果:

假設 maxConcurrentCalls 為 25,maxWaitDuration 為 100。那么,backendA 服務最多可以同時處理 25 個并發請求。如果在同一時刻收到超過 25 個請求,則后面的請求會嘗試等待 100 毫秒。如果在 100 毫秒內仍然無法獲得處理資源,則會被拒絕或拋出異常。

配置 Retry

配置重試:

resilience4j:
  retry:
    instances:
      backendA:
        maxAttempts: 3
        waitDuration: 500

配置項解釋:

  • maxAttempts: 最大重試次數,包括第一次調用在內。這里設置為 3,表示當 backendA 服務調用失敗時,最多會重試 2 次。
  • waitDuration: 重試間隔時間,單位毫秒。這里設置為 500,表示每次重試之前會等待 500 毫秒。

配置含義:

這段配置定義了一個名為 backendA 的 Retry 實例,用于對 backendA 服務或資源的調用進行重試操作。

重試策略: 當 backendA 服務調用失敗時,Retry 實例會根據配置的重試策略進行重試。

  • maxAttempts 規定了最大重試次數。例如,本例中設置為 3,表示當 backendA 服務調用失敗時,最多會重試 2 次。
  • waitDuration 規定了重試間隔時間。例如,本例中設置為 500,表示每次重試之前會等待 500 毫秒。

重試流程:

  • 當調用 backendA 服務發生異常時,Retry 實例會進行重試。
  • 重試之前,會等待 waitDuration 指定的時間。
  • 重試時,會再次調用 backendA 服務。
  • 如果重試成功,則返回結果并結束。
  • 如果重試 maxAttempts 次后仍然失敗,則拋出異常。

通過這種方式,你可以為不同的服務或資源創建 Retry 實例,并根據它們的具體需求進行配置,以提高服務的容錯性和可用性。

配置 Time Limiter

配置時間限制器:

resilience4j:
  timelimiter:
    instances:
      backendA:
        timeoutDuration: 1000

配置項解釋:

timeoutDuration: 操作的超時時間,單位毫秒。這里設置為 1000,表示 backendA 服務的調用必須在 1 秒內完成,否則會被視為超時。

配置含義:

這段配置定義了一個名為 backendA 的 TimeLimiter 實例,用于對 backendA 服務或資源的調用進行超時控制。

超時策略: 當 backendA 服務調用超過 timeoutDuration 指定的時間時,TimeLimiter 實例會認為其超時,并拋出 TimeoutException 異常。

超時效果:

假設 timeoutDuration 為 1000。那么,當調用 backendA 服務時,如果超過 1 秒仍然沒有完成,則會被 TimeLimiter 實例視為超時,并拋出 TimeoutException 異常。

四、、實現功能

實現 Circuit Breaker

在 backendA 服務中使用斷路器:

import io.github.resilience4j.circuitbreaker.annotation.CircuitBreaker;
import org.springframework.stereotype.Service;
import org.springframework.web.client.RestTemplate;

@Service
public class BackendAService {

    private final RestTemplate restTemplate;

    public BackendAService(RestTemplate restTemplate) {
        this.restTemplate = restTemplate;
    }

    @CircuitBreaker(name = "backendA", fallbackMethod = "fallback")
    public String callExternalService() {
        return restTemplate.getForObject("http://external-service/api", String.class);
    }

    public String fallback(Exception e) {
        return "外部服務不可用";
    }
}

實現 Rate Limiter

在 backendA 服務中使用限流器:

import io.github.resilience4j.ratelimiter.annotation.RateLimiter;
import org.springframework.stereotype.Service;

@Service
public class BackendAService {

    @RateLimiter(name = "backendA")
    public String callExternalService() {
        // 外部服務調用邏輯
        return "外部服務的響應";
    }
}

實現 Bulkhead

在 backendA 服務中使用艙壁隔離:

import io.github.resilience4j.bulkhead.annotation.Bulkhead;
import org.springframework.stereotype.Service;

@Service
public class BackendAService {

    @Bulkhead(name = "backendA")
    public String callExternalService() {
        // 外部服務調用邏輯
        return "外部服務的響應";
    }
}

實現 Retry

在 backendA 服務中使用重試:

import io.github.resilience4j.retry.annotation.Retry;
import org.springframework.stereotype.Service;

@Service
public class BackendAService {

    @Retry(name = "backendA")
    public String callExternalService() {
        // 外部服務調用邏輯
        return "外部服務的響應";
    }

實現 Time Limiter

在 backendA 服務中使用時間限制器:

import io.github.resilience4j.timelimiter.annotation.TimeLimiter;
import org.springframework.stereotype.Service;

import java.util.concurrent.CompletableFuture;

@Service
public class BackendAService {

    @TimeLimiter(name = "backendA")
    public CompletableFuture<String> callExternalService() {
        return CompletableFuture.supplyAsync(() -> {
            // 外部服務調用邏輯
            return "外部服務的響應";
        });
    }
}

五、高級主題

自定義配置

如何進行 Resilience4j 的自定義配置:

resilience4j:
  circuitbreaker:
    configs:
      custom:
        slidingWindowSize: 50
        minimumNumberOfCalls: 5

要使用自定義 Circuit Breaker 配置,您需要用 @CircuitBreaker(name = "custom") 注解你的方法。這將指定配置應用于方法的 Circuit Breaker 實例。

性能優化

優化 Resilience4j 在生產環境中的性能:

  • 調整配置參數以平衡性能和穩定性
  • 使用異步調用減少阻塞

問題排查

常見問題及其解決方案:

  • 問題:Circuit Breaker 不工作

解決方案:檢查配置是否正確,確保服務調用符合觸發條件。

六、結語

Resilience4j 提供了一套強大的工具,使你的 Spring Boot 應用更具彈性和可靠性。通過整合 Resilience4j,可以有效地應對各種服務故障和過載情況。隨著 Resilience4j 的不斷發展,我們可以期待更多功能和優化,使其在微服務架構中發揮更大的作用。

責任編輯:趙寧寧 來源: 源話編程
相關推薦

2022-11-16 17:16:41

spring限流

2024-10-06 08:35:44

2023-06-27 07:31:59

微服務容錯庫重試

2025-04-09 11:15:00

服務熔斷服務降分布式系統

2023-03-13 08:02:55

斷路器應用API

2022-04-27 08:55:01

Spring外部化配置

2025-03-26 03:00:00

2025-03-11 08:20:58

2025-02-13 07:45:26

APISpringHTTP

2025-04-01 08:08:29

2025-05-14 04:00:00

2021-06-15 07:33:13

Java函數式編程

2022-03-07 07:33:24

Spring自定義機制線程池

2020-05-25 07:00:00

雙因素認證身份認證密碼

2022-02-15 08:22:28

Neo4jSpring數據庫

2025-02-25 08:00:00

SpringBootLua開發

2022-07-26 16:54:08

QuartzJava

2024-12-03 08:00:00

2021-12-11 13:29:36

SpringBoot 官方

2017-05-09 10:34:21

Spring BootDubbo Activ擴展
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久99视频 | 欧美日韩在线免费观看 | 高清亚洲 | 亚洲精品欧美一区二区三区 | 中文字幕国产精品 | 精品美女视频在线观看免费软件 | 国产一区 | 亚洲免费大片 | 欧美一区二区三区四区视频 | 91视频在线观看 | 国产精品美女久久久久久不卡 | 精品视频国产 | 免费在线成人 | 网站国产 | 91欧美激情一区二区三区成人 | 国产精品一区二区av | 91正在播放| 久久久精品一区二区三区四季av | 午夜影视网 | 一区二区三区免费网站 | 久久久国产精品一区 | 日本色高清 | 天天拍天天操 | 国产精品自拍av | 欧美天堂| 99久久亚洲 | 国产精品视频导航 | 国产在线视频一区二区 | 日韩中文字幕 | a在线视频 | 亚洲欧美中文日韩在线v日本 | 九色91视频| 亚洲国产二区 | 日韩av成人 | 精品美女久久久 | 午夜精品一区二区三区在线视频 | а天堂中文最新一区二区三区 | 久久久精品一区二区三区 | 性高朝久久久久久久3小时 av一区二区三区四区 | www.欧美视频 | 日韩高清三区 |