概述
本文主要通过代码的方式配置Sentinel 规则,实现流控效果。以便更加容易的理解sentinel 实现原理。
Sentinel 简介
Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。 完备的实时监控:Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。 广泛的开源生态:Sentinel 提供开箱即用的与其它开源框架 / 库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。 完善的 SPI 扩展点:Sentinel 提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口来快速地定制逻辑。例如定制规则管理、适配动态数据源等。
Sentinel 基本概念
资源 资源是 Sentinel 的关键概念。它可以是 Java 应用程序中的任何内容,例如,由应用程序提供的服务,或由应用程序调用的其它应用提供的服务,甚至可以是一段代码。在接下来的文档中,我们都会用资源来描述代码块。
只要通过 Sentinel API 定义的代码,就是资源,能够被 Sentinel 保护起来。大部分情况下,可以使用方法签名,URL,甚至服务名称作为资源名来标示资源。
规则 围绕资源的实时状态设定的规则,可以包括流量控制规则、熔断降级规则以及系统保护规则。所有规则可以动态实时调整。
依赖
sentinel 核心包
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-core</artifactId>
<version>1.8.6</version>
</dependency>
全部依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.csp</groupId>
<artifactId>sentinel-core</artifactId>
<version>1.8.6</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
代码
@RestController
@Slf4j
public class SentinelController {
private static final String RESOURCE_NAME = "hello";
private static final String USER_RESOURCE_NAME = "user";
private static final String DEGRADE_RESOURCE_NAME = "DEGRADE";
@RequestMapping(value = "/hello")
public String hello() {
// 1.5.0 版本开始可以直接利用 try-with-resources 特性,自动 exit entry
try (Entry entry = SphU.entry(RESOURCE_NAME)) {
// 被保护的逻辑
log.info("hello world");
return "hello";
} catch (BlockException ex) {
//资源房屋阻止,被限流或被降级
//进行相应的处理操作
log.error("block");
return "被限流了";
} catch (Exception e) {
log.error("流控");
//若需要配置降级规则,则需要通过这种方式积累业务异常
//Tracer.traceEntry(e, entry);
}
return null;
}
@PostConstruct
private void initFlowRules() {
log.info("---------------------------init");
//流控规则
List<FlowRule> rules = new ArrayList<>();
//流控
FlowRule rule = new FlowRule();
//流程保护的资源
rule.setResource(RESOURCE_NAME);
//设置流控规则QPS
rule.setGrade(RuleConstant.FLOW_GRADE_QPS);
rule.setCount(1);
rule.setLimitApp("default");
rules.add(rule);
FlowRuleManager.loadRules(rules);
log.info("---------------------------init end");
}
}
代码解析
本文是通过Sentinel 控制“/hello”的QPS,当超过限制时,提示被限流。
正常访问
超过频率