Spring Cloud中Sentinel的两种限流模式介绍

 更新时间:2023年05月16日 10:10:39   作者:小威要向诸佬学习呀  
如何使用Sentinel做流量控制呢?这篇文章就来为大家详细介绍了Spring Cloud中Sentinel的两种限流模式,感兴趣的小伙伴可以跟随小编一起学习一下

Sentinel流控模式

Sentinel流量控制主要有以下几种模式:

直接失败模式:在达到流量控制阈值后,直接拒绝请求,返回错误信息。

关联模式:当关联的资源达到流量控制阈值时,将触发当前资源的流量控制。

Warm Up模式:在系统启动时,允许一定量的请求通过,防止出现系统冷启动时大量请求被拒绝的情况。

排队等待模式:在达到流量控制阈值后,请求将进入队列等待,直到有资源可用时再处理请求。

热点规则:对于一些热点资源,可以设置特定的流量控制规则,以防止热点资源被过多请求占用导致系统崩溃。

说明:由于篇幅原因,本篇文章先介绍前两种模式,即直接失败模式和关联模式。

直接失败模式

Sentinel的直接失败模式是一种流量控制策略,它可以在系统达到预设的流量阈值时直接拒绝请求,而不是将请求放入队列等待处理。该模式可以避免系统资源过度消耗,并且可以快速响应请求,提高系统的可用性。

具体来说,Sentinel的直接失败模式可以通过以下步骤实现:

1.配置流量阈值:在Sentinel中,可以通过配置规则来设置系统的流量阈值,例如:每秒最多处理100个请求。

2.监控流量:Sentinel会监控系统的流量,当流量达到预设的阈值时,Sentinel会触发流量控制策略。

3.直接拒绝请求:在直接失败模式下,当流量达到阈值时,Sentinel会直接拒绝请求,并返回错误信息给客户端,而不是将请求放入队列等待处理。

4.统计流量:Sentinel会统计系统的流量情况,并根据配置的规则进行限流,以保证系统的稳定性和可用性。

首先,我们需要添加Sentinel依赖:

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

然后,在启动类上添加@EnableSentinel注解启用Sentinel:

@SpringBootApplication
@EnableSentinel
public class DemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }
}

接下来,我们定义一个Controller,其中包含一个需要进行流量控制的方法:

@RestController
public class DemoController {
    @GetMapping("/hello")
    @SentinelResource(value = "hello", fallback = "fallback")
    public String hello() {
        return "Hello, World!";
    }
    public String fallback() {
        return "Sorry, the service is busy, please try again later.";
    }
}

在上面的代码中,我们使用@SentinelResource注解标记了hello()方法,并指定了一个fallback方法。当Sentinel进行流量控制并触发熔断时,会自动调用fallback方法返回一个固定的响应。

接下来,我们需要在Sentinel Dashboard中配置流量控制规则。打开Dashboard,进入流控规则页面,添加一个新的规则,将控制台模式设置为直接失败,并设置阈值和时间窗口等参数。保存规则后,我们就可以开始测试了。

当流量超过阈值时,Sentinel会拒绝请求并返回一个固定的响应,即fallback方法中定义的响应。这就是Sentinel的直接失败模式。

关联模式

Sentinel的关联模式是一种流量控制策略,它可以根据不同的资源之间的关联关系来进行流量控制。比如,如果一个接口的访问频率过高,可能会导致其所依赖的其他接口也受到影响,此时就可以使用关联模式来控制流量。

关联模式的实现需要定义资源之间的关联关系,并为每个资源设置独立的流控规则。在实际使用中,可以通过配置文件或代码来定义关联关系和流控规则。

以下是一个使用代码实现Sentinel关联模式的示例:

// 定义资源关联关系
private static final String RESOURCE_A = "resourceA";
private static final String RESOURCE_B = "resourceB";
private static final String RESOURCE_C = "resourceC";

// 定义流控规则
private static final FlowRule RULE_A = new FlowRule(RESOURCE_A)
    .setCount(10) // 每秒最多处理10个请求
    .setGrade(RuleConstant.FLOW_GRADE_QPS);
private static final FlowRule RULE_B = new FlowRule(RESOURCE_B)
    .setCount(20) // 每秒最多处理20个请求
    .setGrade(RuleConstant.FLOW_GRADE_QPS);
private static final FlowRule RULE_C = new FlowRule(RESOURCE_C)
    .setCount(30) // 每秒最多处理30个请求
    .setGrade(RuleConstant.FLOW_GRADE_QPS);

// 定义资源关联关系
private static final Set<FlowRule> RULES_A = new HashSet<>();
private static final Set<FlowRule> RULES_B = new HashSet<>();
private static final Set<FlowRule> RULES_C = new HashSet<>();
static {
    RULES_A.add(RULE_A);
    RULES_A.add(RULE_B);
    RULES_B.add(RULE_B);
    RULES_C.add(RULE_C);
}

// 注册流控规则
FlowRuleManager.loadRules(RULES_A);
FlowRuleManager.loadRules(RULES_B);
FlowRuleManager.loadRules(RULES_C);

// 定义资源关联关系
DegradeRule degradeRuleA = new DegradeRule(RESOURCE_A)
    .setGrade(RuleConstant.DEGRADE_GRADE_EXCEPTION_COUNT)
    .setCount(5) // 每秒最多处理5个异常
    .setTimeWindow(10); // 统计时间窗口为10秒
DegradeRule degradeRuleB = new DegradeRule(RESOURCE_B)
    .setGrade(RuleConstant.DEGRADE_GRADE_EXCEPTION_COUNT)
    .setCount(10) // 每秒最多处理10个异常
    .setTimeWindow(10); // 统计时间窗口为10秒
DegradeRule degradeRuleC = new DegradeRule(RESOURCE_C)
    .setGrade(RuleConstant.DEGRADE_GRADE_EXCEPTION_COUNT)
    .setCount(15) // 每秒最多处理15个异常
    .setTimeWindow(10); // 统计时间窗口为10秒

// 定义资源关联关系
private static final Set<DegradeRule> DEGRADE_RULES_A = new HashSet<>();
private static final Set<DegradeRule> DEGRADE_RULES_B = new HashSet<>();
private static final Set<DegradeRule> DEGRADE_RULES_C = new HashSet<>();
static {
    DEGRADE_RULES_A.add(degradeRuleA);
    DEGRADE_RULES_A.add(degradeRuleB);
    DEGRADE_RULES_B.add(degradeRuleB);
    DEGRADE_RULES_C.add(degradeRuleC);
}

// 注册降级规则
DegradeRuleManager.loadRules(DEGRADE_RULES_A);
DegradeRuleManager.loadRules(DEGRADE_RULES_B);
DegradeRuleManager.loadRules(DEGRADE_RULES_C);

在上面的代码中,我们定义了三个资源:RESOURCE_A、RESOURCE_B、RESOURCE_C,并为每个资源设置了独立的流控规则和降级规则。同时,我们还定义了资源之间的关联关系,即RESOURCE_A和RESOURCE_B关联,RESOURCE_B和RESOURCE_C关联。

通过这种方式,当RESOURCE_A的流量达到限制时,Sentinel会自动触发降级操作,从而避免RESOURCE_B和RESOURCE_C受到影响。同样地,当RESOURCE_B的流量达到限制时,Sentinel会自动触发降级操作,从而避免RESOURCE_C受到影响。

到此这篇关于Spring Cloud中Sentinel的两种限流模式介绍的文章就介绍到这了,更多相关Spring Cloud Sentinel限流模式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • spring缓存自定义resolver的方法

    spring缓存自定义resolver的方法

    这篇文章主要为大家详细介绍了spring缓存自定义resolver的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • IDEA中Directory创建多级目录的实现

    IDEA中Directory创建多级目录的实现

    本文主要介绍了IDEA中Directory创建多级目录的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • Maven设置JDK版本的两种方法实现

    Maven设置JDK版本的两种方法实现

    本文主要介绍了Maven设置JDK版本的两种方法实现,是通过Apache Maven Compiler Plugin插件实现的,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • 解决一个JSON反序列化问题的办法(空字符串变为空集合)

    解决一个JSON反序列化问题的办法(空字符串变为空集合)

    在平时的业务开发中,经常会有拿到一串序列化后的字符串要来反序列化,下面这篇文章主要给大家介绍了如何解决一个JSON反序列化问题的相关资料,空字符串变为空集合,需要的朋友可以参考下
    2024-03-03
  • 基于Java的guava开源库工具类

    基于Java的guava开源库工具类

    guava是谷歌基于java封装好的开源库,这篇文章主要通过介绍几个好用的guava工具类,感兴趣的朋友可以参考下面文章内容
    2021-09-09
  • springsecurity实现登录验证以及根据用户身份跳转不同页面

    springsecurity实现登录验证以及根据用户身份跳转不同页面

    Spring Security是一种基于Spring框架的安全技术,用于实现身份验证和访问控制,本文介绍了如何使用Spring Security,结合session和redis来存储用户信息,并通过编写特定的登录处理类和Web配置,实现用户登录和注销功能
    2024-09-09
  • spring security的BCryptPasswordEncoder加密和对密码验证的原理分析

    spring security的BCryptPasswordEncoder加密和对密码验证的原理分析

    文章介绍了加密算法和hash算法的基本概念,以及BCryptPasswordEncoder加密和解密的原理,加密算法是可逆的,需要加盐以保证安全性,BCryptPasswordEncoder通过生成盐值并在加密和解密过程中使用,确保相同的明文每次加密结果不同,从而提高安全性
    2024-11-11
  • Java连接Redis全过程讲解

    Java连接Redis全过程讲解

    这篇文章主要介绍了Java连接Redis全过程讲解,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • Java动态规划之硬币找零问题实现示例

    Java动态规划之硬币找零问题实现示例

    本文主要介绍了Java动态规划之硬币找零问题实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • SpringBoot如何优雅地处理全局异常详解

    SpringBoot如何优雅地处理全局异常详解

    这篇文章主要给大家介绍了关于SpringBoot如何优雅地处理全局异常的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用SpringBoot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08

最新评论