spring cloud分布式中,熔断器就是断路器,其实都是一个意思。

为什么要使用熔断器呢?

在分布式中,我们会根据业务或功能将项目拆分为多个服务单元,各个服务单元之间通过服务注册和订阅的方式相互依赖和调用功能,随着项目和业务的不断拓展,服务单元数量也逐渐增多,相互之间的依赖关系也越来越复杂,这时候,可能会某个服务单元出现问题或网络原因依赖调用出错或延迟,此时如果调用该依赖的请求不断增加,那么要调用该服务的服务将都会等待或者出现故障,如果后续连锁反应越来越多,Servlet容器的线程资源会被消耗完毕,导致服务瘫痪。服务与服务的依赖会导致服务之间的故障传播,从而迎来“雪崩效应“。为了解决这种每个点或多个点的故障,就有了熔断器的出现。

什么是熔断器?

熔断器就相当于电路中的保险丝、保护器,它可以实现快速失败,如果它在某一段时间里侦测到许多类似的错误,它将不再访问远程服务器,会强迫以后的访问都会快速失败,从而防止某个服务不断地尝试执行可能会失败的操作,它会使服务继续执行而不用等待修正错误,或者浪费CPU时间去等到长时间的超时产生,从而进入回路方法。熔断器也可以使服务能够诊断错误是否已经修正,如果已经修正,服务会再次尝试调用操作。

1.在调用服务方加入熔断器依赖jar包:

// https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-hystrix

compile group: 'org.springframework.cloud', name: 'spring-cloud-starter-hystrix'

2.在Controller中:

@Controller

//@EnableWebSecurity 安全检查controller还要继承extends WebSecurityConfigurerAdapter

public class PageController {

public static Logger logger=LoggerFactory.getLogger(PageController.class);

@Autowired

private RestTemplate restTemplate;

@HystrixCommand(fallbackMethod = "toIndex1")//断路器进入回路方法

@RequestMapping("/toIndex1")

public String toIndex(Model model){

System.out.println("进入toIndex");

logger.info("执行调用");

String msg=restTemplate.getForEntity("http://project-solr/SolrSearch",String.class).getBody();//project-solr是调用注册中心里的名字

logger.info("调用结束");

model.addAttribute("msg",msg);

return "index";

}

public String toIndex1(Model model){

System.out.println("进入回路方法");

model.addAttribute("msg","服务不可用,请稍后重试");

return "index";

}

}

注意:在调用方服务Controller中的方法上加上@HystrixCommand(fallbackMethod = "回路方法")

这里我让回路方法调用的是toIndex1,要注意回路方法返回值,参数要与原方法一致

在被调用方的方法中制造故障:

3.在调用方的启动类加注解@EnableCircuitBreaker启动熔断器

启动:

可以看到进入了回路方法

当然还可以在调用方进行配置:

hystrix:

command:

default:

execution:

isolation:

thread:

timeoutInMilliseconds: 2000 #请求响应时间 如果过了这个时间就会进入回路方法

circuitBreaker:

requestVolumeThreshold: 2 # 服务降级:此请求连续多少次响应过慢或崩溃 系统就默认把它当成一个崩溃的方法 在一定时间内调用此方法会直接进入回路方法 这样执行更快 默认值是20 请求该方法20次 如果崩溃或响应过慢率大于百分之八十 就会默认它是一个崩溃方法

#timeout:

#enabled: false #取消超时检查 无论线程运行多久 只要不崩溃就不进入回路方法 一般情况不使用

配置完后运行:

运行好几次发现它会前两次会访问并等待相应结果,后面不再访问就直接回应结果进入回路方法

当然这是根据配置:

spring cloud熔断器就说到这里,想了解spring cloud其他内容,请浏览我以前博客

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

java熔断器_详解spring cloud分布式关于熔断器相关推荐

  1. java中batch基础_详解Spring batch 入门学习教程(附源码)

    详解Spring batch 入门学习教程(附源码) 发布时间:2020-09-08 00:28:40 来源:脚本之家 阅读:99 作者:achuo Spring batch 是一个开源的批处理框架. ...

  2. java切面不需要接口了吗_详解Spring AOP 实现“切面式”valid校验

    why: 为什么要用aop实现校验? answer: spring mvc 默认自带的校验机制 @Valid + BindingResult, 但这种默认实现都得在Controller方法的中去接收B ...

  3. java按钮权限控制_详解Spring Security 中的四种权限控制方式

    Spring Security 中对于权限控制默认已经提供了很多了,但是,一个优秀的框架必须具备良好的扩展性,恰好,Spring Security 的扩展性就非常棒,我们既可以使用 Spring Se ...

  4. java 矩阵求逆_详解用java描述矩阵求逆的算法

    今天很开心把困扰几天的问题解决了,在学习线性代数这门课程的时候.想通过程序实现里面的计算方法,比如矩阵求逆,用java代码该如何描述呢? 首先,咱们先用我们所交流语言描述一下算法思路: 1.求出一个矩 ...

  5. java 定时任务插件_详解Spring整合Quartz实现动态定时任务

    最近项目中需要用到定时任务的功能,虽然spring 也自带了一个轻量级的定时任务实现,但感觉不够灵活,功能也不够强大.在考虑之后,决定整合更为专业的Quartz来实现定时任务功能. 普通定时任务 首先 ...

  6. Java扫描配置文件的注解_详解Spring框架注解扫描开启之配置细节

    前言 Spring框架对Bean进行装配提供了很灵活的方式,下面归纳一下主要的方式: 在XML中进行显示配置 在Java中进行显示配置 隐式的bean发现机制和自动装配 而自动装配实现就需要注解扫描, ...

  7. java全局异常处理_详解Spring全局异常处理的三种方式

    在J2EE项目的开发中,不管是对底层的数据库操作过程,还是业务层的处理过程,还是控制层的处理过程,都不可避免会遇到各种可预知的.不可预知的异常需要处理.每个过程都单独处理异常,系统的代码耦合度高,工作 ...

  8. java部署jar还是war优劣_详解Spring Boot 部署jar和war的区别

    本文介绍了Spring Boot 部署jar和war两种方式的区别,分享给大家,具体如下: 1. packaging的方式不同,一种设置成jar一种是war xsi:schemaLocation=&q ...

  9. java batch基础_详解Spring Batch 轻量级批处理框架实践

    实践内容 从 MariaDB 一张表内读 10 万条记录,经处理后写到 MongoDB . 具体实现 1.新建 Spring Boot 应用,依赖如下: org.springframework.boo ...

最新文章

  1. 「欧拉定理」学习笔记(费马小定理)
  2. linux内核模块签名,如何签名内核模块Ubuntu 18.04
  3. windows上使用的免费连接linux终端xshell6,xftp6下载
  4. nginx 非socket代理配置
  5. 前端学习(1803):前端调试之事件伪类练习二
  6. zen cart 操作
  7. paip.提升安全性----用户资金账户模块平账功能
  8. Python3 函数参数
  9. python报错记录No.1
  10. mtkwin10驱动_MTK手机刷机驱动下载|MTK通用USB刷机驱动 Win7/Win10 自动安装版 下载_当下软件园_软件下载...
  11. 将html的echarts导入excel,echarts 数据 表格 excel-求Excel数据导入echarts实现成图的代码,不胜感激!...
  12. 瑞星网络版数据库中 客户端IP地址如何查看?
  13. 计算机里不显示硬盘图标,Win7不显示硬盘图标怎么办?不显示硬盘图标修复方法...
  14. 【U8+】修改或删除凭证提示此分录两清
  15. 对比“码绘”与“手绘”的区别
  16. 机器学习:随机梯度下降法
  17. windows10系统修改c盘user文件夹下的计算机名称
  18. 利用摄像头实现人员活动检测(python+openCV)
  19. Android安卓反编译apk源代码,移动应用开发课程
  20. Linux修改hosts

热门文章

  1. 人事管理系统——考勤系统需求分析
  2. 在线视频观看系列一:视频分享网站分类
  3. Q2 逆势扭亏为盈,群雄环伺之下朴新如何“虎口脱险”?
  4. qt编译太阳神三国杀
  5. Mysql INNODB引擎行锁的3种算法 Record Lock Next-Key Lock Grap Lock
  6. 字符区位码 java_用Java取得汉字的区位码
  7. 用尘埃粒子计数器对高效过滤器检测检漏方法怎样?
  8. 2022国赛中职网搭 windows组策略
  9. Oracle生成日历表
  10. 邱淑贞的女儿太漂亮啦,邱淑贞为她女儿站台!