SpringCloud Alibaba学习(七):Sentinel的降级规则

简介: Sentinel 熔断降级会在调用链路中某个资源出现不稳定状态时(例如调用超时或异常比例升高),对这个资源的调用进行限制,让请求快速失败,避免影响到其它的资源而导致级联错误。

一、降级规则是什么


     

Sentinel 熔断降级会在调用链路中某个资源出现不稳定状态时(例如调用超时或异常比例升高),对这个资源的调用进行限制,让请求快速失败,避免影响到其它的资源而导致级联错误。

     

当资源被降级后,在接下来的降级时间窗口之内,对该资源的调用都自动熔断(默认行为是抛出 DegradeException)。


二、降级规则有什么



1、RT

     

平均响应时间,秒级  


平均响应时间超出阈值且在时间窗口内通过的请求>=5,两个条件同时满足后触发降级;

窗口期过后关闭断路器;


RT最大4900(更大的需要通过-Dcsp.sentinel.statistic.max.rt=XXXX才能生效)


2、异常比例


秒级。


QPS >= 5 且异常比例(秒级统计)超过阈值时,触发降级;时间窗口结束后,关闭降级


3、异常数


分钟级。


异常数(分钟统计)超过阈值时,触发降级;时间窗口结束后,关闭降级


三、配置实战



1、RT


(1)是什么  


c0c203eb3d0d43a6b12d0cc106f44be7.pngb42069889a6f457aa13eb808fb0df42e.png


(2)配置方法


446e1b14147d4cb08f997520e790551c.png


(3)测试


testD方法:

@GetMapping("/testD")
    public String testD() {
        //暂停几秒钟线程
        try { 
            TimeUnit.SECONDS.sleep(1); 
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        log.info("testD 测试RT");
        return "------testD";
    }


使用 JMeter 工具来进行压力测试

060e1a65f2bf449d973fecd0a008ab57.pngdd3fbcbfe9f547968b86fac749de2475.pngb7b47a49c14b43e0b589ab1f5ef746e5.png


然后点击上方的绿色三角形,开始压力测试。


再次刷新testD

01d0853dcce24a8da37754d48f7dd77d.png


已经被限流。


(4)结论

在刚刚JMeter的设置中,永远在1秒钟打进来10个线程(大于5个)调用testD,我们希望200毫秒处理完本次任务,如果超过200毫秒还没处理完(testD睡眠时间为1秒),在未来1秒钟的时间窗口内,断路器打开(保险丝跳闸)微服务不可用,保险丝跳闸断电了。而永远每秒10个线程,那就永远在下一秒微服务不可用。

后续如果停止jmeter,没有这么大的访问量了,断路器关闭(保险丝恢复),微服务恢复正常。


2、异常比例


(1)是什么


eeb6d06002af46d19b533d118aaf2995.png1950fd10307847a69362d062a2fe8e85.png


(2)配置方法


fbbdeb2928784ab89b8700cbdddbe503.png


(3)测试


testD:

@GetMapping("/testD")
    public String testD() {
        //测试异常比例
        int m = 10/0;
        log.info("testD 测试异常比例");
        return "------testD";
    }


再次JMeter压力测试

01d0853dcce24a8da37754d48f7dd77d.png


暂停后,再次访问,直接报错。

aff35fd5e5024fc6977d124af3d096c9.png


(4)结论


按照上述配置,单独访问一次,必然来一次报错一次(int m = 10/0),调一次错一次(错误占比为100%);而当开启jmeter后,直接高并发发送请求,多次调用达到我们的配置条件了,这时断路器开启(保险丝跳闸),微服务不可用,不再报错error而是服务降级了。


当暂停JMeter后,不满足配置条件,再次访问后直接报错。


3、异常数


(1)是什么

e9d56b1e9c0c4cf88d725ccca9268bba.png


也就是说,时间窗口一定要大于60s


e086a5b677864351813a8431661b48d4.png


(2)配置方式


751af869049049c4ad65c622f09afd4d.png


(3)测试

 

testE:

@GetMapping("/testE")
public String testE()
{
    log.info("testE 测试异常比例");
    int age = 10/0;
    return "------testE 测试异常比例";
}


第一次访问testE,报错;而当访问5次后,进入限流。


(4)结论


按照上述配置,单独访问一次,必然来一次报错一次(int age = 10/0),而当访问五次(异常数达到我们设置的五次)后,服务进入熔断。


相关文章
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
人工智能 SpringCloudAlibaba 自然语言处理
SpringCloud Alibaba AI整合DeepSeek落地AI项目实战
在现代软件开发领域,微服务架构因其灵活性、可扩展性和模块化特性而受到广泛欢迎。微服务架构通过将大型应用程序拆分为多个小型、独立的服务,每个服务运行在其独立的进程中,服务与服务间通过轻量级通信机制(通常是HTTP API)进行通信。这种架构模式有助于提升系统的可维护性、可扩展性和开发效率。
4860 2
|
SpringCloudAlibaba 负载均衡 Dubbo
【SpringCloud Alibaba系列】Dubbo高级特性篇
本章我们介绍Dubbo的常用高级特性,包括序列化、地址缓存、超时与重试机制、多版本、负载均衡。集群容错、服务降级等。
1982 7
【SpringCloud Alibaba系列】Dubbo高级特性篇
|
Java Nacos Sentinel
Spring Cloud Alibaba:一站式微服务解决方案
Spring Cloud Alibaba(简称SCA) 是一个基于 Spring Cloud 构建的开源微服务框架,专为解决分布式系统中的服务治理、配置管理、服务发现、消息总线等问题而设计。
2975 13
Spring Cloud Alibaba:一站式微服务解决方案
|
存储 SpringCloudAlibaba Java
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论。
【SpringCloud Alibaba系列】一文全面解析Zookeeper安装、常用命令、JavaAPI操作、Watch事件监听、分布式锁、集群搭建、核心理论
|
SpringCloudAlibaba JavaScript Dubbo
【SpringCloud Alibaba系列】Dubbo dubbo-admin安装教程篇
本文介绍了 Dubbo-Admin 的安装和使用步骤。Dubbo-Admin 是一个前后端分离的项目,前端基于 Vue,后端基于 Spring Boot。安装前需确保开发环境(Windows 10)已安装 JDK、Maven 和 Node.js,并在 Linux CentOS 7 上部署 Zookeeper 作为注册中心。
3992 1
【SpringCloud Alibaba系列】Dubbo dubbo-admin安装教程篇
|
SpringCloudAlibaba Dubbo Java
【SpringCloud Alibaba系列】Dubbo基础入门篇
Dubbo是一款高性能、轻量级的开源Java RPC框架,提供面向接口代理的高性能RPC调用、智能负载均衡、服务自动注册和发现、运行期流量调度、可视化服务治理和运维等功能。
【SpringCloud Alibaba系列】Dubbo基础入门篇
|
人工智能 安全 Java
AI 时代:从 Spring Cloud Alibaba 到 Spring AI Alibaba
本次分享由阿里云智能集团云原生微服务技术负责人李艳林主讲,主题为“AI时代:从Spring Cloud Alibaba到Spring AI Alibaba”。内容涵盖应用架构演进、AI agent框架发展趋势及Spring AI Alibaba的重磅发布。分享介绍了AI原生架构与传统架构的融合,强调了API优先、事件驱动和AI运维的重要性。同时,详细解析了Spring AI Alibaba的三层抽象设计,包括模型支持、工作流智能体编排及生产可用性构建能力,确保安全合规、高效部署与可观测性。最后,结合实际案例展示了如何利用私域数据优化AI应用,提升业务价值。
1465 4
|
人工智能 自然语言处理 Java
Spring Cloud Alibaba AI 入门与实践
本文将介绍 Spring Cloud Alibaba AI 的基本概念、主要特性和功能,并演示如何完成一个在线聊天和在线画图的 AI 应用。
3978 8
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。