zoukankan      html  css  js  c++  java
  • feign服务端出异常客户端处理的方法

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

    1. try...catch方法
    2. 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的默认值。

  • 相关阅读:
    机器学习项目流程(二)探索并可视化数据
    机器学习项目流程(一)初探数据集
    数据类型.md
    keepalived.md
    LVS.md
    tomcat多实例.md
    LANMP常用配置.md
    php-fpm配置参数.md
    Nginx学习.md
    Redis.md
  • 原文地址:https://www.cnblogs.com/lori/p/11157394.html
Copyright © 2011-2022 走看看