在项目开发中,我们的调用方通过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注解是针对自身方法的异常,方法级别的熔断处理!
服务降级:是主逻辑失败采用备用逻辑的过程,
服务熔断:因短时间内多次失败,而被暂时性的忽略,不再使用