feign 回退原因_Spring Cloud Feign整合Hystrix实现容错处理

本文介绍了如何在Spring Cloud项目中整合Feign和Hystrix实现服务容错处理。通过设置`feign.hystrix.enabled=true`开启Feign对Hystrix的支持,展示了使用Fallback和FallbackFactory两种方式进行服务回退。当服务不可用时,回退机制确保了其他服务的正常运行,避免整个请求失败。禁用Hystrix可以通过修改配置文件或在代码中调整。
摘要由CSDN通过智能技术生成

创建一个新的 Maven 项目 hystrix-feign-demo,增加 EurekaClient,Feign,Hystrix 的依赖,然后在属性文件中开启 Feign 对 Hystrix 的支持:

feign.hystrix.enabled=true

1. Fallback 方式

在 Feign 的客户端类上的 @FeignClient 注解中指定 fallback 进行回退(代码如下所示),创建一个 Feign 的客户端类 UserRemoteClient,为其配置 fallback。

@FeignClient (value = "eureka-client-user-service", fallback = UserRemoteClientFallback.class) public interface UserRemoteClient { @GetMapping("/user/hello") String hello(); }

UserRemoteClientFallback 类需要实现 UserRemoteClient 类中所有的方法,返回回退时的内容,代码如下所示。

@Component public class UserRemoteClientFallback implements UserRemoteClient { @Override public String hello() { return "fail"; } }

停掉所有 eureka-client-user-service 服务,然后访问 /callHello 接口,这个时候 eureka-client-user-service 服务是不可用的,必然会触发回退,返回的内容是 fail 字符串,这证明回退生效了。

在这种情况下,如果你的接口调用了多个服务的接口,那么只有 eureka-client-user-service 服务会没数据,不会影响别的服务,如果不用 Hystrix 回退处理,整个请求都将失败。

{

code:200,

message:"",

data:{

id:1,

money:100.12,

name:"fail"

}

}

下面我们将启用 Hystrix 断路器禁用:

feign.hystrix.enabled=false

再次访问 /callHello 可以看到返回的就是 500 错误信息了,整个请求失败。

2. FallbackFactory 方式

通过 fallback 已经可以实现服务不可用时回退的功能,如果你想知道触发回退的原因,可以使用 FallbackFactory 来实现回退功能,代码如下所示。

@Component public class UserRemoteClientFallbackFactory implements FallbackFactory { private Logger logger = LoggerFactory.getLogger(UserRemoteClientFallbackFactory.class); @Override public UserRemoteClient create(final Throwable cause) { logger.error("UserRemoteClient回退:", cause); return new UserRemoteClient() { @Override public String hello() { return "fail"; } }; } }

FallbackFactory 的使用就是在 @FeignClient 中用 fallbackFactory 指定回退处理类,代码如下所示。

@FeignClient(value = "eureka-client-user-service", configuration = FeignConfiguration.class, fallbackFactory = UserRemoteClientFallbackFactory.class)

笔者在这个回退处理的时候,将异常信息通过日志输出了,我们重新调用接口,可以看到异常信息在开发工具的控制台中输出了,FallbackFactory 和 Fallback 唯一的区别就在这里。

Feign 中禁用 Hystrix

禁用 Hystrix 还是比较简单的,目前有两种方式可以禁用,一种是在属性文件中进行全部禁用,默认就是禁用的状态。

feign.hystrix.enabled=false

另一种是通过代码的方式禁用某个客户端,在 Feign 的配置类中增加如下所示的代码。

@Configuration public class FeignConfiguration { @Bean @Scope("prototype") public Feign.Builder feignBuilder() { return Feign.builder(); } }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值