在整个SpringCloud构建微服务的体系中,有一个提供超时机制,限流,熔断,降级最全面的实现:Hystrix(豪猪) 翻译过来表示:自身带刺,有自我保护的意思,外国人起名字还是很有意思滴。当然Hystrix并不是Spring的,而是NetFlix公司开源的。那么Spring只是把它拿过来,在他的基础上面做了一些封装,然后加入到了SpringCloud中,实现高可用的分布式微服务架构。Hystrix博大精深,功能齐全。
https://github.com/Netflix/Hystrix
https://github.com/Netflix/Hystrix/wiki
一定要记住谁调用在谁哪里做处理,而不是被调用方,被调用方服务都挂了,你写降级有什么用?
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-hystrix</artifactId> </dependency>
通过一种叫做“命令模式”的方式,继承(HystrixCommand类)来包裹具体的服务调用
逻辑(run方法), 并在命令模式中添加了服务调用失败后的降级逻辑(getFallback),见
(OrderServiceCommand类)
源码:06-ms-consumer-order-ribbon-hystrix-customizing 通过配置类的方式
用Hystrix的注解@HystrixCommand可以更简单的实现上面的降级逻辑
直接在接口调用方的方法上增加注解@HystrixCommand(fallbackMethod =
“findByIdFallback”)
注解的源码:06-ms-consumer-order-ribbon-hystrix-fallback
在用户微服务工程里将UserController的findById接口增加执行等待时间,让该接口的执行时间变长,Hystrix调用接口默认两秒超时,超时后会自动执行降级方法。
注解的源码:06-ms-provider-user
provider-user,consumber-order,eureka-server 必须都需要启动
源码:
06-ms-consumer-order-ribbon-hystrix-fusing
06-ms-provider-user
里将UserController的findById接口增加模拟报错代码
测试报错和正常的情况,我们可以看到当报错达到一定阈值时,会自动熔断,阈值可以配置 # 一个rolling window内最小的请求数。如果设为20,那么当一个rolling window的时间内(比如说1个rolling window是10秒)收到19个请求,即使19个请求都失败,也不会触发circuit break。默认20 hystrix.command.default.circuitBreaker.requestVolumeThreshold # 触发短路的时间值,当该值设为5000时,则当触发circuit break后的5000毫秒内都会拒绝request,也就是5000毫秒后才会关闭circuit。默认5000 hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds
熔断器模式定义了熔断器开关相互转换的逻辑
服务的健康状况 = 请求失败数 / 请求总数。
熔断器开关由关闭到打开的状态转换是通过当前服务健康状况和设定阈值比较决定的.
源码:06-ms-consumer-order-ribbon-hystrix-threadisolation在用户微服务工程(06-ms-provider-user)里将UserController的findById接口模拟执行等待的代码。
在订单微服务工程(06-ms-consumer-order-ribbon-hystrix-thread-isolation)中修改接口超时配置为20秒。
用注解配置线程池大小
此处可以粗粒度实现隔离,也可以细粒度实现隔离,如下所示。
服务分组+线程池
粗粒度实现,一个服务分组/系统配置一个隔离线程池即可,不配置线
程池名称或者相同分组的线程池名称配置为一样。
服务分组+服务+线程池
细粒度实现,一个服务分组中的每一个服务配置一个隔离线程池,为不同的命令实现配置不同的线程池名称即可。
混合实现
一个服务分组配置一个隔离线程池,然后对重要服务单独设置隔离线程池。
PS:这次说的听不懂其实很正常,这都是BAT这种互联网公司经常用的技术,目前开发的场景都没用过。