「 从0到1学习微服务SpringCloud 」13 断路器Hystrix
背景与功能
在微服务架构中,很多情况下,各个服务之间是相互依赖,一个服务可能会调用了好几个其他服务,假设其中有一个服务故障,便会产生级联故障,最终导致整个系统崩溃无法使用(这称为雪崩效应),Spring Cloud Hystrix正是用来防止雪崩效应的。
功能:服务降级、服务熔断、线程和信号隔离、请求缓存、请求合并以及服务监控等强大功能。
服务降级
定义
优先核心服务,非核心服务不可用或弱可用 比如:商城的微服架构中,突然涌入大量流量,但服务器资源是有限的,商品、订单、支付为核心服务,必须保证这些服务可用;积分、广告为非核心服务,可将其降级为弱可用或不可用。
实现
实现逻辑 1.通过HystrixCommand注解指定
2.fallbackMethod(回退函数)中实现具体降级逻辑
**代码实现(使用eureka-client项目) ** 1.将config相关配置注释掉(不想多开个服务呀)
2.添加maven
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
3.启动类加上@EnableCircuitBreaker注解
4.新建一个controller做测试
//添加Hystrix的注解,并指定回调函数
@HystrixCommand(fallbackMethod = "fallback")
@RequestMapping("/hys/hi")
public String sayHi(){
return hiService.hi();
}
/**
* 上面方法指定的回调函数
* 当上面的方法出现异常或在指定时间未返回时(默认超时时间1s),会调用此函数
* @return
*/
public String fallback(){
return "用户拥挤,请稍后再试!";
}
5.启动eureka-server,eureka-client项目,故意不开启service-hi项目,上面例子中调用hiService.hi()失败,会发生服务降级,调用回调函数
6.测试
浏览器输入http://localhost:8080/hys/hi
细节
若方法中出现异常时或在超时时间(默认1s)内未返回时,会调用回调函数,实现降级处理。
**需要注意:**这里有个超时时间,Hystrix默认1s,这个需要根据实际业务设置,可以通过一下注解进行设置
@HystrixCommand(commandProperties = {
@HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds",value="3000")
},fallbackMethod = "fallback")
依赖隔离
Hystrix会自动实现依赖隔离,这里所指的依赖隔离是线程池隔离。
Hystrix会为每一个@HystrixCommand注解的方法创建一个线程池,这样的话,当某个方法有线程延迟时,也不会影响到其他的方法。
服务熔断
服务熔断的原理就好像我们家里的电闸一样,当电流过大,为了保护电器,会出现跳闸的现象。
服务熔断也是一样,当遇到不断地出现异常的状况时,达到某个阈值时会触发熔断,而降级调用回调函数。
实现
@HystrixCommand(commandProperties = {
//开启熔断
@HystrixProperty(name = "circuitBreaker.enabled",value="true"),
//一个rolling window内最小的请求数。 默认20
// 如果设为20,那么当一个rolling window(统计时间段,默认10s)的时间内收到19个请求,即使19个请求都失败,也不会触发circuit break(熔断)。
@HystrixProperty(name = "circuitBreaker.requestVolumeThreshold",value="10"),
//触发短路的时间值,当该值设为5000时,则当触发circuit break后的5000毫秒内都会拒绝request,也就是5000毫秒后才会关闭circuit(断路器)。默认5000
@HystrixProperty(name = "circuitBreaker.sleepWindowInMilliseconds",value="10000"),
//错误比率阀值,如果错误率>=该值,circuit(断路器)会被打开,并短路所有请求触发fallback。默认50
@HystrixProperty(name = "circuitBreaker.errorThresholdPercentage",value="60")
},fallbackMethod = "fallback")
@GetMapping("/hys/circuitSayHi")
public String circuitSayHi(Integer number){
if(number == 2){
return "success";
}
return hiService.hi();
}
public String fallback(Integer number){
return "用户拥挤,请稍后再试!";
}
测试
背景:当我传递参数number=2的时,服务调用是成功的,否则失败(因service-hi不开启)
1.直接调用
http://localhost:8080/hys/circuitSayHi?number=2 访问成功(用于对比参照)
2.在10秒内(rolling window),调用http://localhost:8080/hys/circuitSayHi10次(我们设置错误率为60%) 因为开始调用时不一定就在一个rolling window开头,所以我们调用10次,肯定会触发熔断
3.然后调用
http://localhost:8080/hys/circuitSayHi?number=2,处在断路状态,仍然调用的是回调函数
配置的使用
hystrix:
command:
default:
circuitBreaker:
#开启熔断
enabled: true
#滚动窗口中将使断路器跳闸的最小请求数量
requestVolumeThreshold: 20
#设置失败百分比的阈值。如果失败比率超过这个值,则断路器跳闸并且进入fallback逻辑
errorThresholdPercentage : 60
execution:
isolation:
thread:
#设置调用者执行的超时时间(单位毫秒)
timeoutInMilliseconds: 2000
#为某个方法设定特殊的配置 方法名
circuitSayHi:
circuitBreaker:
#开启熔断
enabled: true
#滚动窗口中将使断路器跳闸的最小请求数量
requestVolumeThreshold: 10
#设置失败百分比的阈值。如果失败比率超过这个值,则断路器跳闸并且进入fallback逻辑
errorThresholdPercentage : 40
execution:
isolation:
thread:
#设置调用者执行的超时时间(单位毫秒)
timeoutInMilliseconds: 1000
更多配置项,自定谷歌百度
图形化界面
Hystrix提供了一个图形化界面,用于监控断路情况
1.添加maven
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-stream-rabbit</artifactId>
</dependency>
2.添加配置
management:
endpoints:
web:
exposure:
# 开启指定端点
include: 'hystrix.stream'
3.重启项目,打开 http://localhost:8080/hystrix
4.分别调用一下
http://localhost:8080/hys/circuitSayHi?number=2
http://localhost:8080/hys/circuitSayHi
在监控的界面有两个重要的图形信息:一个实心圆和一条曲线。
实心圆:1、通过颜色的变化代表了实例的健康程度,健康程度从绿色、黄色、橙色、红色递减。2、通过大小表示请求流量发生变化,流量越大该实心圆就越大。所以可以在大量的实例中快速发现故障实例和高压实例。
曲线:用来记录2分钟内流浪的相对变化,可以通过它来观察流量的上升和下降趋势。
就讲到这里咯,已同步更新github,下期见~
https://github.com/zhangwenkang0/springcloud-learning-from-0-to-1
如果觉得不错,分享给你的朋友!
一个立志成大腿而每天努力奋斗的年轻人
伴学习伴成长,成长之路你并不孤单!
「 从0到1学习微服务SpringCloud 」13 断路器Hystrix的更多相关文章
- 「 从0到1学习微服务SpringCloud 」10 服务网关Zuul
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...
- 「 从0到1学习微服务SpringCloud 」09 补充篇-maven父子模块项目
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config 「 从0到1学习微服务SpringCloud 」07 RabbitM ...
- 「 从0到1学习微服务SpringCloud 」08 构建消息驱动微服务的框架 Spring Cloud Stream
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...
- 「 从0到1学习微服务SpringCloud 」07 RabbitMq的基本使用
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...
- 「 从0到1学习微服务SpringCloud 」06 统一配置中心Spring Cloud Config
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...
- 「 从0到1学习微服务SpringCloud 」05服务消费者Fegin
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...
- 「 从0到1学习微服务SpringCloud 」04服务消费者Ribbon+RestTemplate
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...
- 「 从0到1学习微服务SpringCloud 」03 Eureka的自我保护机制
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 Eureka的高可用需要 ...
- 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现
系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! Spring Cloud Eureka 基于Netflix Eureka做了二次封装(Spring Clo ...
随机推荐
- ASP.NET MVC 实现页落网资源分享网站+充值管理+后台管理(4)之业务仓储工厂
在创建业务层之前,我们先来熟悉一下业务仓储工厂Bobo.Repository.dll程序集,后续的业务操作,我们都将通过这个程序集中的方法传递数据库操作,其介于数据库操作与业务层之间,详情可前往< ...
- 安卓中运行报错Error:Execution failed for task ':app:transformClassesWithDexForDebug'解决
在androidstuio中运行我的未完项目,报错: Error:Execution failed for task ':app:transformClassesWithDexForDebug'.&g ...
- h5 页面 实现单选题,多选题功能。
效果图: 项目要求: 1:实现单选题和多选题区分 (这个根据后端传来的数据判断 ) 2 单选选中效果 和 多选选中效果(利用input 和label ) 3.答题成功与失败 分单选和多选的情况 ...
- 第二阶段:2.商业需求文档MRD:1.M版本管理
版本管理的例子.V=Version.注意大中小版本的区分.V1.2.2 第一个数字1就是大版本 中间的2就是中版本 末尾的2就是小版本.大版本就是方向的变更,比如我的用户之前主要是面向男性,现在要面向 ...
- Excel读取方式优化(浅谈对规律的认知)
相信大家都接触过对Excel的读取,今天突发奇想,想将自己的一小段经历分享出来.灵活识别列名并将其存到对象数组中. 固定形式的Excel列的读取: 源于我第一次操作Excel,将列名对应成table中 ...
- java 使用 apoi 更新 ppt 中图表的数据
本文源码: 1. https://github.com/zhongchengyi/zhongcy.demos/tree/master/apoi-ppt-chart 2. 在第5节也有核心源码 1 ...
- centos服务器cpu百分之百,top查询不到之“-bash”
把这条注释掉. [root@aaaa ~]# cat /etc/ld.so.preload #/usr/local/lib/libproc.so[root@aaaa ~]# 然后在top
- Elasticsearch基本概念和使用
Elasticsearch基本概念和使用 1.操作索引 1.1.基本概念 Elasticsearch也是基于Lucene的全文检索库,本质也是存储数据,很多概念与MySQL类似的. 对比关系: 索引( ...
- 1shell基础,变量,运算符
1shell基础语法 是一个命令解释器,在操作系统的最外层,负责直接与用户进行对话. 我们输入的命令,计算机时不识别的,这时就需要一种程序来帮助我们进行翻译,变成计算机能识别的二进制程序,同时把计算机 ...
- Jmeter之BeanShell变量使用讲解
一.在测试过程中经常会遇到一些业务逻辑处理需要,单纯的线程设置不能满足,这时候就要使用BeanShell编写一定的脚本 前置处理器:BeanShell PreProcessor,主要接口请求前做一些参 ...