feign服务端出异常客户端处理的方法

在使用feign进行远程方法调用时,如果远程服务端方法出现异常,客户端有时需要捕获,并且把异常信息返回给前端,而如果在开启熔断之后,这个异常会被消化,所以说,如果希望拿到服务端异常,feign.hystrix.enable需要设置为false,而当不开熔断时,我们也有几种方法把拿到服务端的异常信息,下面总结一下。

try...catch方法
feign异常拦截器

try...catch方法

这个方法比较直观,也最好理解,但业务层会有很多try...catch这种代码,所以不是很推荐。

注意:虽然服务端方法返回为ResponseEntity,但出现4xx,5xx这些异常时,还是会抛出一个FeignException的异常,而这对于服务来说,向前端抛出的还是5xx的服务端异常,这不是我们希望看到的。
try {
      ResponseEntity<?> body = productClient.add(name);
      if (body.getStatusCode().equals(HttpStatus.OK)) {
        return "test";
      } else {
        return body.getBody().toString();
      }
    } catch (FeignException ex) {
      return ex.getMessage();
    }

feign异常拦截器

我们比较推荐使用这个方法,注册一个bean对象,当feign调用出现异常时,会触发这个方法,然后我们再统一处理这个异常,向下流继续抛出加工后的错误信息。

/**
 * feign异常拦截器,当从feign抛出异常时走这个对象.
 */
@Configuration
@Slf4j
public class FeignClientErrorDecoder implements ErrorDecoder {

  @Override
  public Exception decode(String methodKey, Response response) {
    logger.info("feign client response:", response);
    String body = null;
    try {
      body = Util.toString(response.body().asReader());
    } catch (IOException e) {
      logger.error("feign.IOException", e);
    }
    if (response.status() >= 400 && response.status() <= 500) {
      throw Exceptions.badRequestParams(body);
    }
    return errorStatus(methodKey, response);
  }
}
注意,使用这个方式,需要在熔断器关闭时才起作用,因为它们的执行过程是,先走这个拦截器,再走熔断的fallback,所以这个异常会被熔断吞掉,返回状态为200,返回值为你的fallback的默认值。

在此我向大家推荐一个架构学习交流圈。交流学习微信:539413949(里面有大量的面试题及答案)里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化、分布式架构等这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容