一、熔断器简介
微服务架构特点就是多服务,多数据源,支撑系统应用。这样导致微服务之间存在依赖关系。如果其中一个服务故障,可能导致系统宕机,这就是所谓的雪崩效应。
1、服务熔断
微服务架构中某个微服务发生故障时,要快速切断服务,提示用户,后续请求,不调用该服务,直接返回,释放资源,这就是服务熔断。
熔断生效后,会在指定的时间后调用请求来测试依赖是否恢复,依赖的应用恢复后关闭熔断。
2、服务降级
服务器高并发下,压力剧增的时候,根据当业务情况以及流量,对一些服务和页面有策略的降级(可以理解为关闭不必要的服务),以此缓解服务器资源的压力以保障核心任务的正常运行。
双十一期间,支付宝很多功能都会提示,[双十一期间,保障核心交易,某某服务数据延迟]。
3、核心依赖
<dependency>
4、核心注解
- @EnableHystrix 启动类注解控制熔断功能。
- @HystrixCommand 方法注解,熔断控制配置。
5、案例模块描述
演示基于Ribbon服务的熔断
node03-consume-8001
演示基于Feign服务的熔断
node03-consume-8002
Eureka注册中心
node03-eureka-7001
两个服务提供方
node03-provider-6001
node03-provider-6002
二、基于Ribbon服务熔断
1、熔断执行方法
/**
2、简单案例
/**
Hystrix默认的超时时间是1秒,超时时间内部响应,就会执行熔断,进入fallback程序。由于Spring的懒加载机制,首次请求往往比较慢,可以通过配置Hystrix超时时间解决。
3、复杂案例
- 配置超时、并发、线程池、指定异常熔断忽略
/**
4、启动类注解
- @EnableHystrix
三、基于Feign服务熔断
1、Jar包说明
通过观察Fegin依赖的JAR可知,Fegin的Jar下包含Hystrix需要的Jar包,这里不用再次导入依赖。
2、熔断配置
Feign用接口实现的声明式Rest请求,所以配置也就在接口上面了。
1)、接口代码
@FeignClient
2)、熔断执行代码
@Component
3)、配置文件
- 开启熔断功能
feign:
hystrix:
enabled: true
3、服务类注解
由于上面的接口和熔断代码是在不同的Jar模块中,所以要在启动类@SpringBootApplication注解中扫描,如下。
@SpringBootApplication
这样案例就结束了。