文章目录
1. 作用
@SentinelResource 允许我们对资源进行定义,比较常用的是资源名称、异常处理等设置
2. 第一个例子
这边定义个简单的接口,我们加了 @SentinelResource 注解:将资源名称设置为 LimitTest1,定义了熔断处理的方法 handleException
@RestController
@RequestMapping("/limit")
public class RateLimitController {
@SentinelResource(value = "LimitTest1", blockHandler = "handleException")
@GetMapping("/test1")
public String test1(String name){
return "Hello:" + name;
}
public String handleException(String name, BlockException e){
return "异常:name=" + name + "," + e.getClass().getCanonicalName() + "\t 服务不可用";
}
}
Sentinel 控制台设置熔断规则,QPS=1
打开浏览器,快速多次访问上面的接口,熔断后输出我们定义的方法:
3. blockHandler兜底的问题
- 如果系统默认的,没有体现我们自己的业务要求
- 依照现有条件,我们自定义的兜底方法和业务代码耦合在一起,不直观
- 每个业务方法都添加一个兜底处理,代码冗余膨胀
- 没有全局统一的处理方法
4. 定义全局兜底方法
创建 CustomBlockHandler 类,里面有一个静态的 handleException 方法
public class CustomBlockHandler {
public static String handleException(BlockException ex){
return "全局的,自定义 HandleException";
}
}
修改原来的 @SentinelResource,增加设置 blockHandlerClass
@SentinelResource(value = "LimitTest2", blockHandlerClass = CustomBlockHandler.class, blockHandler = "handleException")
@GetMapping("/test2")
public String test2(){
return "Limit Test2 ";
}
此时,再出发熔断就会调用全局的方法