@Configuration
public class Resilience4JConfig {
/**
* 10秒超时
*/
final static long timeout = 1000 * 10;
@Resource
CircuitBreakerRegistry circuitBreakerRegistry;
@Resource
TimeLimiterRegistry timeLimiterRegistry;
@Bean
public ReactiveResilience4JCircuitBreakerFactory defaultCustomizer() {
//自定义断路器配置
CircuitBreakerConfig circuitBreakerConfig = CircuitBreakerConfig.custom() //
// 滑动窗口的类型为时间窗口
.slidingWindowType(CircuitBreakerConfig.SlidingWindowType.TIME_BASED)
// 时间窗口的大小为60秒
.slidingWindowSize(60)
// 在单位时间窗口内最少需要5次调用才能开始进行统计计算
.minimumNumberOfCalls(5)
// 在单位时间窗口内调用失败率达到50%后会启动断路器
.failureRateThreshold(50)
// 允许断路器自动由打开状态转换为半开状态
.enableAutomaticTransitionFromOpenToHalfOpen()
// 在半开状态下允许进行正常调用的次数
.permittedNumberOfCallsInHalfOpenState(5)
// 断路器打开状态转换为半开状态需要等待60秒
.waitDurationInOpenState(Duration.ofSeconds(60))
// 所有异常都当作失败来处理
.recordExceptions(Throwable.class)
.build();
ReactiveResilience4JCircuitBreakerFactory factory = new ReactiveResilience4JCircuitBreakerFactory(circuitBreakerRegistry, timeLimiterRegistry);
factory.configureDefault(id -> new Resilience4JConfigBuilder(id)
//超时规则,默认1s
.timeLimiterConfig(TimeLimiterConfig.custom().timeoutDuration(Duration.ofMillis(Resilience4JConfig.timeout)).build())
//设置断路器配置
.circuitBreakerConfig(circuitBreakerConfig)
.build());
return factory;
}
}
参考:Spring Cloud Gateway配置熔断CircuitBreaker_spring cloud gateway circuitbreakerregistry-CSDN博客