微服务消费端通过feign调用微服异常问题

在项目开发中,我们的调用方通过Feign调用微服时,如果微服出现业务异常(例如空指针,或抛出自定义的异常)和非业务异常(参数不合法4xx异常)都会进入到调用方的全局异常拦截器,抛出的code全部转换成了500,这样不友好

实际上只有业务异常feign才会转换成500错误且转成FeignException,空指针不会暴露给调用者

记录一次坑,feign的没有触发fallback原因

{
"status": "ERROR",
"code": "500",
"msg": "request method:GET uri:/test\nError creating bean with name 'com.amez.common.api.feign.ICommonApiFeignClient': FactoryBean threw exception on object creation; nested exception is java.lang.IllegalStateException: Incompatible fallback instance. Fallback/fallbackFactory of type class com.amez.common.api.feign.fallback.CommonFeignClientFallbackFactory is not assignable to interface com.amez.common.api.feign.ICommonApiFeignClient for feign client amez-common-service"
}
@FeignClient的fallbackFactory写成了fallback属性,在调用方开启feign熔断
feign:
    hystrix:
        enabled: true
这样微服暴露的异常只会在控制台打印,但是进入了fallback返回了默认值,不至于调用方线程中断

---

当开启feign的Hystrix配置,同时在启动类上添加@EnableCircuitBreaker 开启服务的熔断时



熔断的方法参数要一致,否则会抛异常!

若提供方微服务出现异常,则会走到降低逻辑,而不会进入熔断!

若提供方微服务正常返回数据,调用方出现异常,则会触发方法的熔断!

总结:feign中也内置了对hystrix的支持,开启feign的hystrix是针对调用微服务的降级处理

@HystrixCommand注解是针对自身方法的异常,方法级别的熔断处理!

服务降级:是主逻辑失败采用备用逻辑的过程,

服务熔断:因短时间内多次失败,而被暂时性的忽略,不再使用



  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值