SpringBoot熔断机制之CircuitBreaker详解

 更新时间:2023年10月08日 10:48:21   作者:代码行间的无聊生活  
这篇文章主要介绍了SpringBoot熔断机制之CircuitBreaker详解,SpringBoot的熔断机制在微服务架构中扮演着重要角色,其中CircuitBreaker是其核心机制之一,用于防止服务的异常状态影响到整个系统的运作,需要的朋友可以参考下

Circuit Breaker

熔断机制在微服务中必不可少,比如故障发生时怎么处理

熔断:半熔断、熔断打开、熔断关闭

  • 熔断关闭: 熔断关闭不会对服务进行熔断,当请求服务失败次数符合设定的规则则进入熔断机制
  • 半熔断: 部分请求根据规则调用当前服务,如果请求成功且符合规则则认为当前服务恢复正常,关闭熔断;
  • 熔断打开:请求不再进行调用当前服务,内部设置时钟一般为(MTTR:平均故障处理时间),当打开时长达到所设时钟则进入半熔断状态。
  • 基于服务策略触发

服务降级

提到熔断机制还得提下服务降级服务降级往往因为服务压力过大,比如京东双促之类的服务降级方式比较多

简单举个列子:在各大电商大促销的时候往往详情页有时候是不会看到推荐之类的信息。

熔断与服务降级关系

  • 都是为实现服务高可用
  • 最终的表现方式类似 

基于Feign实现

  • Feign 本身支持Hystrix,不再需要引入相关的jar
  • Feign实现只支持类的方式,不支持方法
  • 如果启用 Hytrix则设置 enabled = true
feign:
  hystrix:
    enabled: true

基于上次写的FeignServer module来测试此功能

fallback

简单的fallback应用,在FeignClient中加入 fallback

@FeignClient(value = "ribbonserver" , fallback = FeignServerImpl.class )
public interface FeignServer {
    @RequestMapping(value ="/testRealRibbon",method= RequestMethod.GET)
    String testRealRibbon(@RequestParam("content") String content);
}

创建 FeignServerImpl 实现类,实现FeignClient的 FeignServer

@Component
public class FeignServerImpl implements FeignServer {
    public String testRealRibbon(@RequestParam("content") String content) {
        return content + ", it's fallback with feign";
    }
}

测试验证

  • 启动 discovery 、configserver、apigateway、feignserver
  • 因为feign调用的是ribbonserver的服务,所以ribbonserver不用启动

测试结果为: Hello World, it’s fallback with feign

启动ribbonserver

测试结果为: Hello World, for Spring Boot

fallbackFactory

如果需要触发来进行熔断,则需要用 fallbackFactory

在FeignClient中加入 fallbackFactory

@FeignClient(value = "ribbonserver" , fallbackFactory = FeignServerFactoryImpl.class )
public interface FeignServer {
    @RequestMapping(value ="/testRealRibbon",method= RequestMethod.GET)
    String testRealRibbon(@RequestParam("content") String content);
}

创建 FeignServerFactoryImpl 实现类,实现FeignClient的 FeignServer

@Component
public class FeignServerFactoryImpl implements FallbackFactory<FeignServer> {
    /**
     * Returns an instance of the fallback appropriate for the given cause
     *
     * @param cause corresponds to {@link AbstractCommand#getFailedExecutionException()}
     *              often, but not always an instance of {@link FeignException}.
     */
    public FeignServer create(Throwable cause) {
        return new FeignServer() {
            public String testRealRibbon(String content) {
                return content + ", it's fallback Factory with feign";
            }
        };
    }
}

测试验证

  • 启动 discovery 、configserver、apigateway、feignserver
  • 因为feign调用的是ribbonserver的服务,所以ribbonserver不用启动

测试结果为: Hello World, it’s fallback Factory with feign

启动ribbonserver

测试结果为: Hello World, for Spring Boot

基于Ribbon实现

  • 大致与Feign差不多,但需要引入 Hystrix,spring-cloud-starter-hystrix
  • Feign 因为本身支持 hystrix,所以不需要引入
  • @HystrixCommand 指定 fallback的方法
@Controller
public class RibbonController {
    @Autowired
    RestTemplate restTemplate;
    private final static String serverURI = "http://ribbonserver/";
    @RequestMapping("/test")
    @HystrixCommand(fallbackMethod = "testError")
    public String testRibbon(String content) {
        System.out.println(content);
        restTemplate.getForEntity(serverURI+"testRealRibbon?content="+content,String.class);
        return "index";
    }
    public String testError() {
        return "404";
    }
}

到此这篇关于SpringBoot熔断机制之CircuitBreaker详解的文章就介绍到这了,更多相关SpringBoot熔断机制内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 解决spring-cloud-config 多服务共享公共配置的问题

    解决spring-cloud-config 多服务共享公共配置的问题

    这篇文章主要介绍了解决spring-cloud-config 多服务共享公共配置的问题,本文通过多种方法给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • 利用logback 设置不同包下的日志级别

    利用logback 设置不同包下的日志级别

    这篇文章主要介绍了利用logback 设置不同包下的日志级别,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-12-12
  • 一篇文章带你入门Java UML的类图

    一篇文章带你入门Java UML的类图

    这篇文章主要为大家详细介绍了Java UML的类图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-02-02
  • MyBatis中Collection和Association的底层实现原理分析

    MyBatis中Collection和Association的底层实现原理分析

    本文详细介绍了MyBatis中`<collection>`和`<association>`标签的底层实现原理,探讨了它们如何通过缓存和对象创建机制将数据库结果集高效地映射为Java对象,文章通过实际的数据库示例和伪代码示例,展示了这两个标签在一对多和一对一关系中的具体工作方式
    2025-11-11
  • 大厂禁止SpringBoot在项目使用Tomcat容器原理解析

    大厂禁止SpringBoot在项目使用Tomcat容器原理解析

    这篇文章主要为大家介绍了大厂禁止SpringBoot在项目使用Tomcat原理解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • Spring中的Devtools源码解析

    Spring中的Devtools源码解析

    这篇文章主要介绍了Spring中的Devtools源码解析,Spring中的Devtools是一个开发工具,旨在提高开发人员的生产力和开发体验,它提供了一系列功能,包括自动重启、热部署、远程调试等,使开发人员能够更快速地进行代码修改和调试,需要的朋友可以参考下
    2023-10-10
  • 浅谈java8中map的新方法--replace

    浅谈java8中map的新方法--replace

    下面小编就为大家带来一篇浅谈java8中map的新方法--replace。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • java递归算法的实例详解

    java递归算法的实例详解

    在本篇文章里小编给大家整理了关于java递归算法的实例内容,以及相关知识点总结,需要的朋友们可以学习下。
    2020-02-02
  • SpringBoot+WebMagic实现网页爬虫的示例代码

    SpringBoot+WebMagic实现网页爬虫的示例代码

    本文是对spring boot+WebMagic+MyBatis做了整合,使用WebMagic爬取数据,然后通过MyBatis持久化爬取的数据到mysql数据库,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • Spring的RedisTemplate的json反序列泛型丢失问题解决

    Spring的RedisTemplate的json反序列泛型丢失问题解决

    本文主要介绍了Spring RedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性能需求选择方案,下面就来具体了解一下
    2025-07-07

最新评论