微服务消费端通过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注解是针对自身方法的异常,方法级别的熔断处理!

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

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



你可能感兴趣的:(和光同尘)