非Feign客户端消费者服务在使用Hystrix时,仅需要在指定方法上声明注解@HystrixCommand,并通过fallbackMethod属性指定服务降级处理方法即可.然而,Feign客户端消费者服务是以接口的形式进行服务消费的,其接口方法并不存在方法体,所以相对于非Feign客户端的消费者服务来说,Feign实现Hystrix另有方案.其实,Feign已经整合了Hystrix组件,需要手动开启方可使用.
Feign开启Hystrix组件
在application.yml文件中,feign: hystrix: enabled: true -->开启hystrix组件
Feign使用Hystrix实现服务降级方式一:@FeignClient注解fallback属性实现
服务降级指定好后,启动eureka和fegin客户端服务.
然后在浏览器上输入 http://localhost:8181/user/2 进行测试.由于Feign接口获取不到生产者实例,所以会执行服务降级方法.
以上,便通过@FeignClient的属性fallback实现了服务的降级处理.
Feign使用Hystrix实现服务降级方式二:@FeignClient注解fallbackFactory属性实现
①很多场景下,需要了解服务降级的原因,那么就可以使用@FeignClient的fallbackFactroy属性实现服务降级,以便满足要求.
创建一个UserFeignClientFallbackFactory类并实现泛型为UserFeignClient的FallbackFactory接口,
并重写FallbackFactory接口的create(Throwable throwable)方法,输出throwable对象即可查看服务降级处理的原因.
@FeignClient注解使用fallbackFactroy属性指定服务降级处理类即可
然后在浏览器上输入 http://localhost:8181/user/2 进行测试.由于Feign接口获取不到生产者实例,所以会执行服务降级方法.
Run Dashboard控制台端输出如下
2020-09-16 16:52:33.895 INFO 3260 --- [loud-provider-1] c.g.c.f.UserFeignClientFallbackFactory : 服务降级处理原因:java.lang.RuntimeException: com.netflix.client.ClientException: Load balancer does not have available server for client: springcloud-provider
以上,便通过@FeignClient的属性fallbackFactory实现了服务的降级处理.
如果需要让不同的异常返回不同的处理结果时,可以通过throwable对象的类型判断即可.
Hystrix监控Feign
引入Actuator和Hystrix的依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
启动类声明@EnableHystrix注解,开启对/actuator/hystrix.stream端点的支持
application.yml配置actuator端点暴露(SpringBoot2.0版本需要手动配置)
然后启动项目,在浏览器输入地址 http://localhost:8182/actuator/hystrix.stream
此时,访问地址http://localhost:8182/user/2,让feign服务执行一次服务降级方法.
再次在浏览器输入地址 http://localhost:8182/actuator/hystrix.stream
由此可知,Feign已实现被Hystrix监控.同样的,Feign可以拓展使用Hystrix Dashboard进行监控,方便直观的查看信息.