概述
Sentinel 是面向分布式服务架构的流量控制组件,主要以流量为切入点,从流量控制、熔断降级、系统自适应保护等多个维度来帮助您保障微服务的稳定性
基本概念
资源
资源是 Sentinel 的关键概念。它可以是 Java 应用程序中的任何内容,例如,由应用程序提供的服务,或由应用程序调用的其它应用提供的服务,甚至可以是一段代码。在接下来的文档中,我们都会用资源来描述代码块。
只要通过 Sentinel API 定义的代码,就是资源,能够被 Sentinel 保护起来。大部分情况下,可以使用方法签名,URL,甚至服务名称作为资源名来标示资源。
资源的定义方式
我们可以通过两种方式定义资源,分别是注解和代码
规则
围绕资源的实时状态设定的规则,可以包括流量控制规则、熔断降级规则以及系统保护规则。所有规则可以动态实时调整。
熔断降级
Sentinel有两种熔断设计
通过并发线程数进行限制
当某个资源出现不稳定的情况下,例如响应时间变长,对资源的直接影响就是会造成线程数的逐步堆积。当线程数在特定资源上堆积到一定的数量之后,对该资源的新请求就会被拒绝。堆积的线程完成任务后才开始继续接收请求
通过响应时间对资源进行降级
当依赖的资源出现响应时间过长后,所有对该资源的访问都会被直接拒绝,直到过了指定的时间窗口之后才重新恢复
快速使用
此案例使用Spring注解完成
一、引入依赖
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-core</artifactId>
<version>版本号</version>
</dependency>
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-annotation-aspectj</artifactId>
<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解释
- 第一列:发生的时间戳
- 第二列:发生的时间
- 第三列:资源名称
- 第四列:通过资源的次数
- 第五列:阻止通过资源的次数
- 第六列:成功执行完成的请求个数
- 第七列:用户自定义异常的发生次数
- 第八列:分均响应时长