0
点赞
收藏
分享

微信扫一扫

SentinelResource 统一配置blockHandler方法

兜底方案 面临的问题

1.系统默认的,没有体现我们自己的业务要求

2.依照现有条件,我们自定义的处理方法又和业务代码耦合在一块,不直观。

3.每个业务方法都添加一个兜底的,那代码膨胀加剧。

4.全局统一的处理方法没有体现。

自定义限流处理逻辑

创建CustomerBlockHandler类用于自定义限流处理逻辑

SentinelResource 统一配置blockHandler方法_自定义

 

 

package com.ckfuture.springcloud.alibaba.myHandler;

import com.alibaba.csp.sentinel.slots.block.BlockException;
/*
用户自定义的兜底方法类
*/
public class CustomerBlockHandler {
public static String handlerException(BlockException exception){
return "用户自定义兜底方法1~";
}

public static String handlerException2(BlockException exception){
return "用户自定义兜底方法2~";
}
}

 调用方式:

@GetMapping("/testCustomer")
@SentinelResource(value = "testCustomer",blockHandlerClass = CustomerBlockHandler.class,blockHandler = "handlerException")
public String testCustomer(@RequestParam(value = "p1",required=false) String p1,
@RequestParam(value="p2",required = false) String p2){
return "------testCustomer";
}

 

SentinelResource 统一配置blockHandler方法_处理方法_02

 

 对应如图:

SentinelResource 统一配置blockHandler方法_限流_03

 



举报

相关推荐

0 条评论