当前位置:网站首页>【微服务|Sentinel】@SentinelResource详解
【微服务|Sentinel】@SentinelResource详解
2022-07-01 22:29:00 【步尔斯特】
之前我们写过的文章中提到,在热点参数限流处,我们只能使用@SentinelResource注解来定义资源,才能生效,那么这个注解到底还有何用处呢?
Sentinel 提供了 @SentinelResource 注解用于定义资源,并提供了 AspectJ 的扩展用于自动定义资源、处理 BlockException 等。
介绍
@SentinelResource 注解包含以下属性:
- value:资源名称,必需项(不能为空)
- entryType:entry 类型,可选项(默认为 EntryType.OUT)
- blockHandler / blockHandlerClass: blockHandler 对应处理 BlockException 的函数名称,可选项。blockHandler 函数访问范围需要是 public,返回类型需要与原方法相匹配,参数类型需要和原方法相匹配并且最后加一个额外的参数,类型为 BlockException。blockHandler 函数默认需要和原方法在同一个类中。若希望使用其他类的函数,则可以指定 blockHandlerClass 为对应的类的 Class 对象,注意对应的函数必需为 static 函数,否则无法解析。
- fallback:fallback 函数名称,可选项,用于在抛出异常的时候提供 fallback 处理逻辑。fallback 函数可以针对所有类型的异常(除了 exceptionsToIgnore 里面排除掉的异常类型)进行处理。fallback 函数签名和位置要求:
- 返回值类型必须与原函数返回值类型一致;
- 方法参数列表需要和原函数一致,或者可以额外多一个 Throwable 类型的参数用于接收对应的异常。
- fallback 函数默认需要和原方法在同一个类中。若希望使用其他类的函数,则可以指定 fallbackClass 为对应的类的 Class 对象,注意对应的函数必需为 static 函数,否则无法解析。
- defaultFallback(since 1.6.0):默认的 fallback 函数名称,可选项,通常用于通用的 fallback 逻辑(即可以用于很多服务或方法)。默认 fallback 函数可以针对所以类型的异常(除了 exceptionsToIgnore 里面排除掉的异常类型)进行处理。若同时配置了 fallback 和 defaultFallback,则只有 fallback 会生效。defaultFallback 函数签名要求:
- 返回值类型必须与原函数返回值类型一致;
- 方法参数列表需要为空,或者可以额外多一个 Throwable 类型的参数用于接收对应的异常。
- defaultFallback 函数默认需要和原方法在同一个类中。若希望使用其他类的函数,则可以指定 fallbackClass 为对应的类的 Class 对象,注意对应的函数必需为 static 函数,否则无法解析。
- exceptionsToIgnore(since 1.6.0):用于指定哪些异常被排除掉,不会计入异常统计中,也不会进入 fallback 逻辑中,而是会原样抛出。
特别地,若 blockHandler 和 fallback 都进行了配置,则被限流降级而抛出 BlockException 时只会进入 blockHandler 处理逻辑。若未配置 blockHandler、fallback 和 defaultFallback,则被限流降级时会将 BlockException 直接抛出。
案例
public class TestService {
// 对应的 `handleException` 函数需要位于 `ExceptionUtil` 类中,并且必须为 static 函数.
@SentinelResource(value = "test", blockHandler = "handleException", blockHandlerClass = {
ExceptionUtil.class})
public void test() {
System.out.println("Test");
}
// 原函数
@SentinelResource(value = "hello", blockHandler = "exceptionHandler", fallback = "helloFallback")
public String hello(long s) {
return String.format("Hello at %d", s);
}
// Fallback 函数,函数签名与原函数一致或加一个 Throwable 类型的参数.
public String helloFallback(long s) {
return String.format("Halooooo %d", s);
}
// Block 异常处理函数,参数最后多一个 BlockException,其余与原函数一致.
public String exceptionHandler(long s, BlockException ex) {
// Do some log here.
ex.printStackTrace();
return "Oops, error occurred at " + s;
}
}
边栏推荐
- Advanced skills of testers: a guide to the application of unit test reports
- MySQL -- index of InnoDB storage engine
- Flink SQL command line connection yarn
- Single step debugging analysis of rxjs observable of operator
- 毕业季,既是告别,也是新的开始
- Sogou wechat app reverse (II) so layer
- 若干互联网暴露面的收敛及处置建议
- Cisco test -- the concept and configuration test of routing
- leetcode - 287. Find duplicates
- Explain the use of locksupport in detail
猜你喜欢
Programming English vocabulary notebook
Using emqx cloud to realize one machine one secret verification of IOT devices
激发新动能 多地发力数字经济
Congratulations on the release of friends' new book (send welfare)
Unable to climb hill sort, directly insert sort
You probably haven't noticed the very important testing strategy in your work
Explain ThreadLocal in detail
[MySQL] index classification
Sogou wechat app reverse (II) so layer
Hide the creation and use of users
随机推荐
Multi picture alert ~ comparison of Huawei ECs and Alibaba cloud ECS
Cisco test -- the concept and configuration test of routing
OpenVINO 模型性能评估工具—DL Workbench
MySQL -- deduction of index storage model
Electron学习(三)之简单交互操作
locust的使用
MySQL -- index of MyISAM storage engine
Pytorch nn. functional. Simple understanding and usage of unfold()
Cisco -- an external tool for WAN's concept examination
用JpaTransactionManager操作数据库事务
转--利用C语言中的setjmp和longjmp,来实现异常捕获和协程
若干互联网暴露面的收敛及处置建议
转载csdn文章操作
Jielizhi, production line assembly link [chapter]
[daily training] 326 Power of 3
Convergence and disposal suggestions of some Internet exposure surfaces
思科--高可用和高可靠网络考试
"Trust machine" empowers development
Congratulations on the release of friends' new book (send welfare)
el-input文本域字数限制,超过显示变红并禁止输入