以前当 Sentinel 对接口进行限流时,我们可以通过 @SentinelResource 注解中的 blockHander 属性定义限流后处理结果。但是有一点不足:处理逻辑会和业务接口的代码偶会,所以为了解决这个问题,我们可以通过Sentinel自定义限流处理逻辑来最终解决此问题。
第一步:创建CustomerHandler类,用于Sentinel自定义处理逻辑
package com.liuyangjava.handler; import com.alibaba.csp.sentinel.slots.block.BlockException; public class CustomerHandler { public static String handlerException(BlockException e) { return "自定义限流处理逻辑,此时请求数过多"; } }
第二步:创建RateController类
package com.liuyangjava.controller; import com.alibaba.csp.sentinel.annotation.SentinelResource; import com.liuyangjava.handler.CustomerHandler; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class RateController { @GetMapping("/sentinel/customHandler") @SentinelResource(value = "customHandler", blockHandlerClass = CustomerHandler.class, blockHandler = "handlerException") public String customHandler() { return "sentinel service is success"; } }
第三步:添加限流规则
注意:
- @SentinelResource注解不支持private方法
- fallback属性,主要管Java的异常
- blockHandler属性,主要管配置规则,如:限流规则,降级规则,热点参数限流等等