hystrix 总结


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 默认配置类


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叫我三师弟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值