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容错类关系:
如果同时配置FeignErrorDecoder
与FallbackFactory
,那么异常会先进入到FeignErrorDecoder
然后再FallbackFactory
中。