环境:SpringBoot2。3。12。RELEASESpringCloudHoxton。SR12简介 SpringCloud断路器提供了不同断路器实现之间的抽象。它提供了在应用程序中使用的一致API,让开发人员选择最适合应用程序需求的断路器实现。 SpringCloud支持以下断路器实现:Resilience4JSentinelSpringRetry阻塞式应用 要在代码中创建断路器,可以使用CircuitBreakerFactoryAPI。当你在类路径中包含SpringCloudCircuitBreakerstarter时,将自动为你创建实现此API的bean。下面的例子展示了如何使用这个API的一个简单例子:dependencygroupIdorg。springframework。cloudgroupIdspringcloudstartercircuitbreakerresilience4jartifactIddependency或者(反应式)dependencygroupIdorg。springframework。cloudgroupIdspringcloudstartercircuitbreakerreactorresilience4jartifactIddependency 简单API应用ServicepublicstaticclassUsersService{privateRestTemplaterest;privateCircuitBreakerFactorycbFactory;publicDemoControllerService(RestTemplaterest,CircuitBreakerFactorycbFactory){this。restrest;this。cbFactorycbFactory;}publicUsersgetUser(){returncbFactory。create(remoteUser)。run(()rest。getForObject(100,Users。class),throwable用户用户信息失败);}} CircuitBreakerFactory。createAPI创建一个名为CircuitBreaker的类实例。run方法接受一个Supplier和一个Function。Supplier是你要包装在断路器中的代码。Function是在断路器跳闸时运行的后备功能。Function被传递导致触发回退的Throwable。如果你不想提供一个回退,你可以选择排除它。反应式应用 如果ProjectReactor位于类路径上,你还可以为响应式代码使用ReactiveCircuitBreakerFactory。下面的例子展示了如何做到这一点:ServicepublicstaticclassDemoControllerService{privateReactiveCircuitBreakerFactorycbFactory;privateWebClientwebClient;publicDemoControllerService(WebClientwebClient,ReactiveCircuitBreakerFactorycbFactory){this。webClientwebClient;this。cbFactorycbFactory;}publicMonoUsersgetUser(){returnwebClient。get()。uri(100)。retrieve()。bodyToMono(Users。class)。transform(itcbFactory。create(remoteUser)。run(it,throwablereturnMono。just(获取用户失败)));}} ReactiveCircuitBreakerFactory。createAPI创建一个名为ReactiveCircuitBreaker的类实例。run方法将一个Mono或Flux包在一个断路器中。你可以选择配置一个回退函数,该函数将在断路器被触发并传递导致故障的Throwable时被调用。配置 你可以通过创建Customizer类型的bean来配置断路器。Customizer接口有一个方法(称为customize),它接受对象进行自定义。 有关如何自定义给定实现的详细信息,请参阅以下文档: Resilience4J: https:docs。spring。iospringcloudcommonsspringcloudcircuitbreakercurrentreferencehtmlspringcloudcircuitbreaker。htmlconfiguringresilience4jcircuitbreakers Sentinel: https:github。comalibabaspringcloudalibabablob2。2。xspringcloudalibabadocssrcmainasciidoccircuitbreakersentinel。adoccircuitbreakerspringcloudcircuitbreakerwithsentinelE28094E2808Bconfiguringsentinelcircuitbreakers SpringRetry: https:docs。spring。iospringcloudcircuitbreakerdocscurrentreferencehtmlspringcloudcircuitbreaker。htmlconfiguringspringretrycircuitbreakers 一些CircuitBreaker实现,如Resilience4JCircuitBreaker,在每次调用CircuitBreakerrun时调用自定义方法。它可能是低效的。在这种情况下,你可以使用CircuitBreakeronce方法。 下面的例子展示了io。github。resilience4j。circuitbreaker。CircuitBreaker的方法。断路器消耗事件。Customizer。once(circuitBreaker{circuitBreaker。getEventPublisher()。onStateTransition(eventlog。info({}:{},event。getCircuitBreakerName(),event。getStateTransition()));},CircuitBreaker::getName) 完毕!!! SpringCloudSentinel熔断降级 SpringCloudSentinel流控限流 SpringCloudSentinel基础配置 SpringMVC异步请求方式 Spring中字段格式化的使用详解 SpringBootWebFlux整合SpringSecurity进行权限认证 Spring自定义Advisor以编程的方式实现AOP SpringSecurity权限控制系列(七) SpringSecurity权限控制系列(一) SpringSecurity权限控制系列(五) SpringSecurity权限控制系列(六) SpringSecurity权限控制系列(二) SpringSecurity权限控制系列(三) SpringSecurity权限控制系列(四) SpringCloudFunction快速入门