feign服务端发现异常客户端处理的方法介绍

发布时间:2020-10-05 19:08:30 作者:张占岭
来源:脚本之家 阅读:152

前言

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

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的默认值。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对亿速云的支持。

推荐阅读:
  1. thrift编写服务端 客户端
  2. 关于Nagios的NRPE服务端客户端安装

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

feign 异常 服务端

上一篇:nginx实现动静分离的示例代码

下一篇:quartz定时执行任务,并配置web.xml的操作方法

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》