> 文档中心 > Feign实现统一异常处理器

Feign实现统一异常处理器

我们可以实现异常拦截,在feign抛出异常后进行一些自定义处理

创建FeignErrorDecoder:

@Configurationpublic class FeignErrorDecoder extends ErrorDecoder.Default {    private final Logger log = LoggerFactory.getLogger(FeignErrorDecoder.class);    @Override    public Exception decode(String methodKey, Response response) { Exception exception = super.decode(methodKey, response); // 如果是RetryableException,则返回继续重试 if (exception instanceof RetryableException) {     return exception; } else {     // 可以自定义一些逻辑,比如抛出一个其他的(统一个异常)     exception = new RuntimeException("Feign调用出错了"); } return exception;    }}

修改@FeignClient:
configuration中加入FeignErrorDecoder

@FeignClient(value = "b-service",configuration = {FeignErrorDecoder.class})public interface TestFeign {   ....}

与Fallback容错类关系:
如果同时配置FeignErrorDecoderFallbackFactory,那么异常会先进入到FeignErrorDecoder然后再FallbackFactory中。