@SentinelResource注解使用
@SentinelResource属性介绍
Value:资源名称,必需项(不能为空)
blockHandler:处理BlockException的函数名称(可以理解对Sentinel的配置进行方法兜底)。函数要求:
必须是public修饰
返回类型与原方法一致
参数类型需要和原方法相匹配,并在最后加BlockException类型的参数。
默认需和原方法在同一个类中,若希望使用其他类的函数,可配置blockHandlerClass,并指定blockHandlerClass里面的方法。
blockHandlerClass:存放blockHandler的类。对应的处理函数必须是public static修饰,否则无法解析,其他要求:同blockerHandler。
fallback:用于在抛出异常的时候提供fallback处理逻辑(可以理解为对java异常情况方法兜底)。fallback函数可以针对所有类型的异常(除了exceptionsToIgnore里面排除掉的异常类型)进行处理。函数要求:
返回类型与原方法一致
参数类型需要和原方法相匹配,Sentinel 1.6开始,也可以在方法最后加Throwable类型的参数。
默认需和原方法在同一个类中。若希望使用其他类的函数,可配置fallbackClass,并制定fallbackClass里面的方法。
fallbackClass:存放fallback的类。对应的处理函数必须static修饰,否则无法解析,其他要求:同fallback。
最后根据实际代码详细说明
**
最终说明:
1.如果sentinel配置了限流规则 当访问QPS达到阈值 则会触发blockHandler中对应的方法**
2.如果该方法出现java异常错误(空指针,运算异常等情况)则会触发fallback中对应的方法
blockHandler方法如下
public static TableDataInfo<Login> queryAll_detail(PageQuery pageQuery, BlockException exception){
return TableDataInfo.build("我是兜底方法 只与sentinel的配置规则有关😀😀");
}
fallback方法如下
public static TableDataInfo<Login> queryAll(PageQuery pageQuery,Throwable throwable){
return TableDataInfo.build("我是java程序异常时所调用的fallback方法");
}