SpringCloud服务熔断及降级Hystrix(四)

阅读更多

1.服务熔断

当Hystrix Command请求后端服务失败数量超过一定比例(默认50%), 断路器会切换到开路状态(Open). 这时所有请求会直接失败而不会发送到后端服务. 断路器保持在开路状态一段时间后(默认5秒), 自动切换到半开路状态(HALF-OPEN).

这时会判断下一次请求的返回情况, 如果请求成功, 断路器切回闭路状态(CLOSED), 否则重新切换到开路状态(OPEN). Hystrix的断路器就像我们家庭电路中的保险丝, 一旦后端服务不可用, 断路器会直接切断请求链, 避免发送大量无效请求影响系统吞吐量, 并且断路器有自我检测并恢复的能力.

2.服务降级

Fallback相当于是降级操作. 对于查询操作, 我们可以实现一个fallback方法, 当请求后端服务出现异常的时候, 可以使用fallback方法返回的值. fallback方法的返回值一般是设置的默认值或者来自缓存.告知后面的请求服务不可用了,不要再来了。

2.1调用方的服务降级

2.1.1在consumer项目添加hystrix依赖

  1. org.springframework.cloud
  2. spring-cloud-starter-netflix-hystrix

2.1.1在consumer项目controller添加测试方法

  1. @RequestMapping("/testHystrix")
  2. @HystrixCommand(fallbackMethod="hystrixFallbackMethod",commandKey="provider")
  3. public String testHystrix(){
  4. String result = providerService.providerReuslt();
  5. return "testHystrix result="+result;
  6. }
  7. public String hystrixFallbackMethod(){
  8. return "hystrixFallbackMethod invoker.";
  9. }

2.1.3在consumer启动主类添加启动hystrix的注解

  1. @EnableHystrix

2.1.4启动测试

启动注册中心及consumer访问 
http://127.0.0.1:30010/testHystrix

2.2服务方的服务降级

2.2.1添加服务接口回调类

  1. @Component
  2. public class ProviderServiceFallback implements ProviderService{
  3. @Override
  4. public String providerReuslt(){
  5. return "ProviderServiceFallback invoker~!";
  6. }
  7. }

2.2.2在服务接口上指定回调类

@FeignClient(value=”provider”, fallback=ProviderServiceFallback.class/**针对接口设置错误回调,如果和@HystrixCommand同时存在则先执行这里*/)

2.2.3在配置文件开启feign的hystrix特性

  1. #开启feign的熔断降级机制
  2. feign:
  3. hystrix:
  4. enabled: true

2.2.4启动测试

依次启动注册中心和consumer再次访问 
http://127.0.0.1:30010/testHystrix

你可能感兴趣的:(SpringCloud)