概述
目录
Feign 整合 Hystrix 实现容错处理
Fallback 方式
FallbackFactory 方式
Feign 中禁用 Hystrix
Feign 整合 Hystrix 实现容错处理
在属性文件中开启 Feign 对 Hystrix 的支持:
feign.hystrix.enabled=true
Fallback 方式
在 Feign 的客户端类上的 @FeignClient
注解中指定 fallback
进行回退:
@FeignClient(value = "blog-user-service", fallback = UserFeignClientFallback.class)
UserFeignClientFallback
类需要实现 UserFeignClient
类中所有的方法,返回回退时的内容,代码如下所示:
@Component
public class UserFeignClientFallback implements UserFeignClient {
@Override
public String findById(Integer id) {
return "fail" + id;
}
}
停掉所有 blog-user-service 服务,然后访问 /user/query/1
接口,这个时候 blog-user-service 服务是不可用的,必然会触发回退,返回的内容是 fail1
字符串,这证明回退生效了。
在这种情况下,如果你的接口调用了多个服务的接口,那么只有 blog-user-service 服务会没数据,不会影响别的服务,如果不用 Hystrix 回退处理,整个请求都将失败。
FallbackFactory 方式
通过 fallback
已经可以实现服务不可用时回退的功能,如果你想知道触发回退的原因,可以使用 FallbackFactory
来实现回退功能,代码如下所示:
@Component
public class UserFeignClientFallbackFactory implements FallbackFactory<UserFeignClient> {
@Override
public UserFeignClient create(Throwable throwable) {
System.err.println("UserFeignClient 回退:" + throwable);
return new UserFeignClient() {
@Override
public String findById(Integer id) {
return "fail" + id;
}
};
}
}
FallbackFactory
的使用就是在 @FeignClient
中用 fallbackFactory
指定回退处理类,代码如下所示:
@FeignClient(value = "blog-user-service", fallbackFactory = UserFeignClientFallbackFactory.class)
我们重新调用接口,可以看到异常信息在开发工具的控制台中输出了,FallbackFactory
和 Fallback
唯一的区别就在这里。
Feign 中禁用 Hystrix
禁用 Hystrix 还是比较简单的,目前有两种方式可以禁用,一种是在属性文件中进行全部禁用,默认就是禁用的状态。
feign.hystrix.enabled=false
另一种是通过代码的方式禁用某个客户端,在 Feign 的配置类中增加如下所示的代码:
@Configuration
public class FeignConfig {
@Bean
@Scope("prototype")
public Feign.Builder feignBuilder() {
return Feign.builder();
}
}
最后
以上就是沉默红酒为你收集整理的Spring Cloud 学习笔记五:搭建微服务工程之Feign 整合 Hystrix 实现容错处理Feign 整合 Hystrix 实现容错处理的全部内容,希望文章能够帮你解决Spring Cloud 学习笔记五:搭建微服务工程之Feign 整合 Hystrix 实现容错处理Feign 整合 Hystrix 实现容错处理所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复