在 Feign中使用断路器
添加依赖
Feign是自带断路器的,如果在Dalston版本的Spring Cloud中,它没有默认打开。需要需要在配置文件中配置打开它,本项目我们是不需要打开的。
feign: hystrix: enabled: true
服务注册
修改HomeClient
类 ,@FeignClient 注解
,加上fallbackFactory
指定新建的HystrixClientFallbackFactory 工厂类
在程序的启动类 RibbonConsumerApplication
通过 @EnableHystrix
开启 Hystrix
/** * 描述: 指定这个接口所要调用的 提供者服务名称 "eureka-provider" **/ @FeignClient(value ="eureka-provider",fallbackFactory = HystrixClientFallbackFactory.class) public interface HomeClient { @GetMapping("/") String consumer(); }
新加的类HystrixClientFallbackFactory.java
@Component public class HystrixClientFallbackFactory implements FallbackFactory<HomeClient> { @Override public HomeClient create(Throwable throwable) { return () -> "feign + hystrix ,提供者服务挂了"; } }
测试断路器
依次启动项目:
spring-cloud-eureka-service
spring-cloud-eureka-provider-1
spring-cloud-eureka-provider-2
spring-cloud-eureka-provider-3
spring-cloud-feign-consumer-hystrix
启动该工程后,访问服务注册中心,查看服务是否都已注册成功:http://localhost:8761/
在命令窗口curl http://localhost:9000/hello
,发现一切正常
或者浏览器get 请求http://localhost:9000/hello
F5 刷新
停止 spring-cloud-eureka-provider-1
提供者,端口为:8081服务
再次访问命令窗口curl http://localhost:9000/hello
,断路器已经生效,提示:Feign + hystrix
,提供者服务挂了。