本文我们来介绍下在使用Feign来做服务调用的情况下怎么通过Hystrix实现服务降级处理。
使用feign做服务调用时,provider和consumer需要依赖相同的service服务,本文仅仅创建consumer服务,其他相关服务参考git案例:https://github.com/q279583842q/SpringCloud-dpb-Demo
feign中默认是关闭对Hystrix的支持的,我们需要放开设置
spring.application.name=shop-product-consumer-hystrix
server.port=9090
#设置服务注册中心地址,指向另一个注册中心
eureka.client.serviceUrl.defaultZone=http://dpb:123456@eureka1:8761/eureka/,http://dpb:123456@eureka2:8761/eureka/
#Feign 默认是不开启 Hystrix 的。默认为:false
feign.hystrix.enabled=true
业务层接口中我们不需要再继承自service中的父接口了,直接在接口中声明一模一样的方法接口
/**
* feign 做服务降级处理
* 不需要继承 ProductService接口
* fallback属性关联托底数据类
*/
@FeignClient(name="shop-product-provider" )
public interface ProductConsumerService {
@RequestMapping(value="/product/findAll",method= RequestMethod.GET)
public List<Product> findAll();
}
添加返回托底数据的类
/**
* @program: springcloud-feign-prodcut-consumer-hystrix
* @description: fallback类
* @author: 波波烤鸭
* @create: 2019-06-12 21:35
*/
@Component
public class ProductServiceFallback implements ProductConsumerService {
/**
* 能够返回托底数据的 fallback 方法
* @return
*/
@Override
public List<Product> findAll() {
List<Product> list = new ArrayList<>();
list.add(new Product(-1, "我是托底数据"));
return list;
}
}
在service接口中关联托底数据
分别启动provider和consumer服务,正常访问
关闭provider,然后访问,获取到了托底数据,降级成功