服务降级(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);
    }

效果

  • 连续三次异常后服务被降级
  • 再进行访问还是异常,再次访问直接降级
相关推荐
瀚高PG实验室24 分钟前
HGDB集群(安全版)repmgr手动切换主备库
java·数据库·安全·瀚高数据库
刘新明198935 分钟前
Frida辅助分析OLLVM虚假控制流程(下)
java·开发语言·前端
第二只羽毛1 小时前
重载和继承的实践
java·开发语言
王嘉俊9251 小时前
设计模式--适配器模式:优雅解决接口不兼容问题
java·设计模式·适配器模式
王嘉俊9251 小时前
设计模式--组合模式:统一处理树形结构的优雅设计
java·设计模式·组合模式
道19931 小时前
50 台小型无人车与50套穿戴终端 5 公里范围内通信组网方案深度研究
java·后端·struts
迎風吹頭髮1 小时前
UNIX下C语言编程与实践35-UNIX 守护进程编写:后台执行、脱离终端、清除掩码与信号处理
java·c语言·unix
光军oi2 小时前
全栈开发杂谈————JAVA微服务全套技术栈详解
java·开发语言·微服务
帮帮志2 小时前
目录【系列文章目录】-(关于帮帮志,关于作者)
java·开发语言·python·链表·交互
聪明的笨猪猪2 小时前
Java Spring “MVC ”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试