使用Sentinel注解,配置了fallback,发现throw exception不起作用,通过阅读源码
@Aspect public class SentinelResourceAspect { ....
try {
ContextUtil.enter(resourceName);
entry = SphU.entry(resourceName, entryType);
Object result = pjp.proceed();
return result;
} catch (BlockException ex) {
return handleBlockException(pjp, annotation, ex);
} finally {
if (entry != null) {
entry.exit();
}
ContextUtil.exit();
}
只有在捕获 BlockException 时才进入handleBlockException
private Object handleBlockException(ProceedingJoinPoint pjp, SentinelResource annotation, BlockException ex) throws Exception { // Execute fallback for degrading if configured. Object[] originArgs = pjp.getArgs(); if (isDegradeFailure(ex)) { Method method = extractFallbackMethod(pjp, annotation.fallback()); if (method != null) { return method.invoke(pjp.getTarget(), originArgs); } } // Execute block handler if configured. Method blockHandler = extractBlockHandlerMethod(pjp, annotation.blockHandler(), annotation.blockHandlerClass()); if (blockHandler != null) { // Construct args. Object[] args = Arrays.copyOf(originArgs, originArgs.length + 1); args[args.length - 1] = ex; if (isStatic(blockHandler)) { return blockHandler.invoke(null, args); } return blockHandler.invoke(pjp.getTarget(), args); } // If no block handler is present, then directly throw the exception. throw ex; }
换句话说,@SentinelResource的fallback只在抛出BlockException时才会触发fallback等相关策略?
原提问者GitHub用户anjia0532
如果设计的初衷即是如此,那么建议在wiki进行标明,因为从hystrix转过来的人会假定,fallback即为函数异常(超时,exception,降级,熔断)后执行的兜底函数。会像我一样,误以为是bug,但是其实是feature。
原回答者GitHub用户anjia0532
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。