Feign的调用报错时,降级处理方式,fallBackFactory

本文介绍了在Feign调用出现错误时,如何通过fallBackFactory实现降级处理。详细讨论了项目结构,包括remoteCdsService和remoteCdsFallbackFactory的设置。当Feign接口调用失败时,系统会转向RemoteCdsFallbackFactory的create方法执行自定义逻辑,返回默认值。此外,文章还提到了Feign注解的contextId属性,用于在微服务中区分多个FeignClient接口调用同一服务提供者的情况,防止启动失败。

Feign的调用报错时,降级处理fallBackFactory

项目结构:

image-20220905100225659

代码:
remoteCdsService
package com.gsafety.framework.api;

import com.alibaba.fastjson.JSONObject;
import com.gsafety.framework.api.constant.ServiceNameConstants;
import com.gsafety.framework.api.factory.RemoteRcsFallbackFactory;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;

/**
 * @author wzx
 * @Description 公共资源服务
 * @Date 2022/8/19 10:48
 */
@FeignClient(contextId = "remoteRcsService", value = ServiceNameConstants.RCS_SERVICE, fallba
如果你希望 Feign 在超的情况下不抛出异常,而是返回 `null`,可以通过以下方式实现: --- ### ✅ 解决方案 #### 1. **使用 `fallback` 或 `fallbackFactory`** 通过设置 Feign降级类,可以在调用失败(包括超返回 `null`。 ```java @FeignClient(name = "service-name", fallback = MyFeignClientFallback.class) public interface MyFeignClient { @GetMapping("/api") String callApi(); } @Component public class MyFeignClientFallback implements MyFeignClient { @Override public String callApi() { return null; // 返回 null } } ``` #### 2. **使用 `fallbackFactory`(推荐)** `fallbackFactory` 可以获取异常信息,更灵活。 ```java @FeignClient(name = "service-name", fallbackFactory = MyFeignClientFallbackFactory.class) public interface MyFeignClient { @GetMapping("/api") String callApi(); } @Component public class MyFeignClientFallbackFactory implements FallbackFactory<MyFeignClient> { @Override public MyFeignClient create(Throwable cause) { return new MyFeignClient() { @Override public String callApi() { // 可记录日志 return null; // 返回 null } }; } } ``` #### 3. **在调用处捕获异常并返回 null** 如果你不想使用降级类,也可以在调用 Feign 方法捕获异常并返回 `null`。 ```java public String safeCallApi() { try { return myFeignClient.callApi(); } catch (Exception e) { // 可选:记录日志 return null; } } ``` --- ### ✅ Feign 配置(application.yml) 确保 Feign 的熔断和降级功能已启用: ```yaml feign: client: config: default: connectTimeout: 3000 readTimeout: 3000 spring: cloud: openfeign: enable-circuit-breaker: true ``` 同确保引入了 `spring-cloud-starter-openfeign` 和 `resilience4j` 或 `Hystrix`(根据你的项目依赖)。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值