Spring Alibaba Sentinel 基础理论知识

概述

Sentinel 是面向分布式服务架构的流量控制组件,主要以流量为切入点,从流量控制、熔断降级、系统自适应保护等多个维度来帮助您保障微服务的稳定性

基本概念

资源

资源是 Sentinel 的关键概念。它可以是 Java 应用程序中的任何内容,例如,由应用程序提供的服务,或由应用程序调用的其它应用提供的服务,甚至可以是一段代码。在接下来的文档中,我们都会用资源来描述代码块。

只要通过 Sentinel API 定义的代码,就是资源,能够被 Sentinel 保护起来。大部分情况下,可以使用方法签名,URL,甚至服务名称作为资源名来标示资源。

资源的定义方式

我们可以通过两种方式定义资源,分别是注解和代码

规则

围绕资源的实时状态设定的规则,可以包括流量控制规则、熔断降级规则以及系统保护规则。所有规则可以动态实时调整。

熔断降级

Sentinel有两种熔断设计

通过并发线程数进行限制

当某个资源出现不稳定的情况下,例如响应时间变长,对资源的直接影响就是会造成线程数的逐步堆积。当线程数在特定资源上堆积到一定的数量之后,对该资源的新请求就会被拒绝。堆积的线程完成任务后才开始继续接收请求

通过响应时间对资源进行降级

当依赖的资源出现响应时间过长后,所有对该资源的访问都会被直接拒绝,直到过了指定的时间窗口之后才重新恢复

快速使用

此案例使用Spring注解完成

一、引入依赖

<dependency>
    <groupId>com.alibaba.cspgroupId>
    <artifactId>sentinel-coreartifactId>
    <version>版本号version>
dependency>
<dependency>
    <groupId>com.alibaba.cspgroupId>
    <artifactId>sentinel-annotation-aspectjartifactId>
    <version>版本号version>
dependency>

二、定义资源

@SentinelResource("TestServiceImpl.test1")
public String test1(String s) {
    log.debug(s);
    return s + " ;test1";
}

三、配置限流规则

@Bean
public ApplicationRunner runListener() {
    return args -> {
        // 定义流量规则
        List<FlowRule> flowRules = new ArrayList<>();
        FlowRule flowRule = new FlowRule("TestServiceImpl.test1");
        flowRule.setGrade(RuleConstant.FLOW_GRADE_QPS);
        flowRule.setCount(1);
        flowRules.add(flowRule);
        // 添加限流规则
        FlowRuleManager.loadRules(flowRules);
        log.debug("配置限流规则成功");
    };
}

四、检查结果

服务启动后,会在控制台输出Sentinel log base directory is: xxxxxx,这里的xxxxxx就是日志的根目录,可以在这里找到${appName}-metrics.log.日期的文件,可以查看到结果

log解释

  • 第一列:发生的时间戳
  • 第二列:发生的时间
  • 第三列:资源名称
  • 第四列:通过资源的次数
  • 第五列:阻止通过资源的次数
  • 第六列:成功执行完成的请求个数
  • 第七列:用户自定义异常的发生次数
  • 第八列:分均响应时长

规则种类

跳转到规则种类详解

流量控制详解

跳转到流量控制详解

动态规则

跳转到动态规则详解

集群限流

跳转到集群限流详解

你可能感兴趣的:(JAVA)