hystrix 是一个服务隔离框架
------------------------------------------
服务雪崩
某个上游接口响应很慢,导致多个下游接口也跟着变慢,占用大量服务器连接资源,导致其他正常的接口没有资源可用,最终造成服务大面积不可用
------------------------------------------
服务隔离
为了避免服务雪崩,对一些慢接口进行隔离,设置这些接口的最大并发数,并引入熔断机制
------------------------------------------
服务限流
高并发情况下,防止服务被大量请求压垮,可以限制请求数量
------------------------------------------
服务隔离策略
1.线程池隔离 - 默认策略
hystrix 把请求放在线程池中执行,由独立的线程接收请求, 会产生线程的变化
2.信号量隔离
采用一个全局变量来控制并发量,每个请求进来全局变量加 1,当加到配置中的阈值时就不再接受用户请求了
------------------------------------------
hystrix 线程池隔离下 传递请求上下文数据
ThreadLocal / RequestContextHolder 无法跨线程传递数据
官方推荐通过实现 HystrixConcurrencyStrategy 来完成数据跨线程传递
------------------------------------------
熔断
在统计时间窗,某个服务的请求数达到阈值,并且请求失败的比例达到阈值,断路器开启,阻止后续请求继续发送,过了睡眠时间窗后,断路器转为半开状态,并为后续的一条请求放行,如果此条请求能够成功返回则表明服务可用,熔断结束,否则继续维持熔断状态, 当发生熔断时,走降级方法, 简化处理或抛出异常信息
------------------------------------------
服务降级
服务降级是对服务调用过程出现异常的友好封装, 降级方法的方法签名要和业务方法一样
降级的 5 种情况
1.failure 抛出异常
2.timeout 超时
3.short circuited 断路器打开
4.thread pool rejected 线程池拒绝
5.semaphore rejected 信号量拒绝
例外
HystrixBadRequestException
不触发 fall back, 不会被计数进入熔断, 一般是由非法参数或非系统异常引起, 根据响应进行异常封装或直接处理
------------------------------------------
熔断发生的三个必要条件
1.统计时间窗口
metrics.rollingStats.timeInMilliseconds
默认 10000 毫秒
2.请求次数必须达到一定数量
circuitBreaker.requestVolumeThreshold
默认 20 次
3.失败率达到指定失败率
circuitBreaker.errorThresholdPercentage
默认 50%
上述 3 个条件缺一不可,必须全部满足才能开启 hystrix 熔断功能
------------------------------------------
熔断器的三个状态
1.关闭状态
用户请求可以到达服务提供方
2.开启状态
用户请求不能到达服务提供方的, 直接走降级方法
3.半开状态
当 hystrix 熔断开启后, 过了睡眠时间窗后,断路器转为半开状态,并为后续的一条请求放行,如果请求返回成功,熔断器就变成关闭状态,如果请求失败,熔断器就变成开启状态
------------------------------------------
Hystrix 高并发下响应慢的请求上
HystrixCommand 有两种方式
1.继承
2.注解
客户端
1.jar 包导入
spring-cloud-starter-netflix-hystrix
2.配置启动类
@EnableHystrix
3.代码使用
配置 @HystrixCommand 及异常降级方法 fallbackMethod
------------------------
hystrix dashboard
是一款针对 Hystrix 进行实时监控的工具, 比如各 Hystrix Command 的成功请求数, 错误请求数,超时请求数, 熔断数等数据
------------------------------------
turbine -- 聚合 n 个 hystrix.stream
使用 Hystrix Dashboard 可以看到单个应用内的服务信息, Turbine 用于汇总系统内多个服务的数据并显示到 Hystrix Dashboard 上
------------------------------------------------
HystrixThreadPoolProperties - hystrix threadpool 默认配置类