服务降级(Sentinel)

服务降级

采用 @SentinelResource 注解方式实现, 必要的依赖必须引入 以及 切面Bean

接口代码

java 复制代码
    @RequestMapping("/degrade")
    @SentinelResource(value = DEGRADE_RESOURCE_NAME, blockHandler = "blockHandlerForDegrade",
            entryType = EntryType.IN)
    public User degrade(String id) {
        // 异常
        throw new RuntimeException("异常");
    }

降级处理

注意: 方法的访问权限、参数格式 和 流控的一致

java 复制代码
    public User blockHandlerForDegrade(String id, BlockException be) {
        logger.info("++++++++服务降级");
        return new User(id, "服务降级了!!!");
    }

降级规则

java 复制代码
    @PostConstruct
    private static void initDegradeRules() { // 通常设置在服务调用端
        List<DegradeRule> degradeRuleList = new ArrayList<>();

        DegradeRule degradeRule = new DegradeRule();
        // 设置资源名称
        degradeRule.setResource(DEGRADE_RESOURCE_NAME);
        // 设置规则策略 -> 异常数
        degradeRule.setGrade(RuleConstant.DEGRADE_GRADE_EXCEPTION_COUNT);
        // 触发熔断异常数量
        degradeRule.setCount(2);
        // 熔断时长 单位:秒
        // 一旦触发熔断,再次请求对应的接口会调用降级处理方法
        // 熔断时长过后--半开状态: 恢复接口请求调用, 如果一次请求就异常, 再次熔断, 不会根据设置来计算是否熔断
        degradeRule.setTimeWindow(10);
        // 触发熔断最小请求数
        degradeRule.setMinRequestAmount(2);
        // 统计时长 单位:毫秒  默认:1000ms
        degradeRule.setStatIntervalMs(60 * 1000 );

        // 一分钟内: 执行下了两次  出现了两次异常  就会触发熔断

        degradeRuleList.add(degradeRule);

        DegradeRuleManager.loadRules(degradeRuleList);
    }

效果

  • 连续三次异常后服务被降级
  • 再进行访问还是异常,再次访问直接降级
相关推荐
kfyty7258 小时前
集成 spring-ai 2.x 实践中遇到的一些问题及解决方案
java·人工智能·spring-ai
猫头虎8 小时前
如何排查并解决项目启动时报错Error encountered while processing: java.io.IOException: closed 的问题
java·开发语言·jvm·spring boot·python·开源·maven
李少兄8 小时前
在 IntelliJ IDEA 中修改 Git 远程仓库地址
java·git·intellij-idea
忆~遂愿8 小时前
ops-cv 算子库深度解析:面向视觉任务的硬件优化与数据布局(NCHW/NHWC)策略
java·大数据·linux·人工智能
小韩学长yyds9 小时前
Java序列化避坑指南:明确这4种场景,再也不盲目实现Serializable
java·序列化
仟濹9 小时前
【Java基础】多态 | 打卡day2
java·开发语言
Re.不晚9 小时前
JAVA进阶之路——无奖问答挑战2
java·开发语言
Ro Jace9 小时前
计算机专业基础教材
java·开发语言
mango_mangojuice10 小时前
Linux学习笔记(make/Makefile)1.23
java·linux·前端·笔记·学习
程序员侠客行10 小时前
Mybatis连接池实现及池化模式
java·后端·架构·mybatis