Sentinel 流控注解使用

大概原理:通过反射解析注解 @SentinelResource信息完成调用,处理方法,类似AOP编程

处理方法的返回类型要保持一致,参数和顺序保持一致, 可以在参数列表最后加

com.alibaba.csp.sentinel.slots.block.BlockException;

java 复制代码
    /**
     * 如果不在同类,需要指明类名和方法名并且方法必须是静态方法
     */
    @GetMapping("/add2")
    @SentinelResource(value = "add", blockHandlerClass = {FlowContrlHandler.class}, blockHandler = "flow")
    public String add2() {
        System.out.println("下单成功!开始远程调用库存服务");
        return stockServiceFeign.reduct();
    }

    /**
     * 如果在同类,只需要指明方法名
     */
    @GetMapping("/flow")
    @SentinelResource(value = "flow", blockHandler = "flowControlHandler")
    public String flow() {
        return "正常访问";
    }
    
    public String flowControlHandler(BlockException e) {
        return "Sentinel: 请求频繁!请稍后再试!";
    }
java 复制代码
package com.ldj.cloud.order.handler;

import com.alibaba.csp.sentinel.slots.block.BlockException;

/**
 * User: ldj
 * Date: 2024/4/18
 * Time: 23:51
 * Description: No Description
 */
public class FlowContrlHandler {

    public static String flow(BlockException e) {
        return "Sentinel_Static: 请求频繁!请稍后再试!";
    }
}
相关推荐
小bo波6 小时前
使用Thread子类创建线程 VS 使用Runnable接口创建线程的区别
java·多线程·thread·并发编程·runnable
SamDeepThinking7 小时前
高并发场景下,CompletableFuture与ForkJoinPool该如何取舍?
java·后端·面试
张不才10 小时前
CPU 100% 了怎么办?Java 性能排障的标准化操作
java·后端
shepherd11111 小时前
吞吐量提升 10 倍:高并发大批量数据处理任务的架构演进与性能调优
java·后端·架构
plainGeekDev14 小时前
单例模式 → object 声明
android·java·kotlin
用户2986985301415 小时前
Java 实现 Word 文档文本与图片提取的方法
java·后端
SimonKing16 小时前
铁子,IntelliJ IDEA 2026.1.3来了,升不升?
java·后端·程序员
咖啡八杯1 天前
GoF设计模式——策略模式
java·后端·spring·设计模式
用户128526116021 天前
我把祖传Java项目重构后,接口响应从3s砍到了200ms,只改了这几行代码
java