SpringBoot -- 熔断机制 Circuit Breaker

2024-06-03 09:58

本文主要是介绍SpringBoot -- 熔断机制 Circuit Breaker,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Circuit Breaker


  • 熔断机制在微服务中必不可少,比如故障发生时怎么处理
  • 熔断:半熔断、熔断打开、熔断关闭 

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

服务降级


  • 提到熔断机制还得提下服务降级
  • 服务降级往往因为服务压力过大,比如京东双促之类的
  • 服务降级方式比较多,简单举个列子:在各大电商大促销的时候往往详情页有时候是不会看到推荐之类的信息。
  • 熔断与服务降级关系 

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

基于Feign实现

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

基于上次写的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);
}
  • 1
  • 2
  • 3
  • 4
  • 5

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

@Component
public class FeignServerImpl implements FeignServer {public String testRealRibbon(@RequestParam("content") String content) {return content + ", it's fallback with feign";}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

测试验证

  • 启动 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);}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

创建 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";}};}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17

测试验证

  • 启动 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 {@AutowiredRestTemplate 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";}
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18

代码

代码请移步 Github参考地址

如有疑问请加公众号(K171),如果觉得对您有帮助请 github start 
公众号_k171

这篇关于SpringBoot -- 熔断机制 Circuit Breaker的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1026663

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

Springboot处理跨域的实现方式(附Demo)

《Springboot处理跨域的实现方式(附Demo)》:本文主要介绍Springboot处理跨域的实现方式(附Demo),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录Springboot处理跨域的方式1. 基本知识2. @CrossOrigin3. 全局跨域设置4.

springboot security使用jwt认证方式

《springbootsecurity使用jwt认证方式》:本文主要介绍springbootsecurity使用jwt认证方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录前言代码示例依赖定义mapper定义用户信息的实体beansecurity相关的类提供登录接口测试提供一