当前位置: 代码迷 >> 综合 >> Sentinel: 分布式系统的流量防卫兵
  详细解决方案

Sentinel: 分布式系统的流量防卫兵

热度:28   发布时间:2023-11-24 10:58:44.0

1、Sentinel 介绍

       随着微服务的流行,服务和服务之间的稳定性变得越来越重要。 Sentinel 以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。

Sentinel 具有以下特征:

  • 丰富的应用场景: Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、实时熔断下游不可用应用等。

  • 完备的实时监控: Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。

  • 广泛的开源生态: Sentinel 提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。

  • 完善的 SPI 扩展点: Sentinel 提供简单易用、完善的 SPI 扩展点。您可以通过实现扩展点,快速的定制逻辑。例如定制规则管理、适配数据源等。

2、Sentinel 入门项目

新建Spring Boot项目:sentinel-demo,导入Spring mvc依赖和spring-cloud-starter-alibaba-sentinel依赖包。完整的项目依赖包如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.1.3.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.example</groupId><artifactId>sentinel-demo</artifactId><version>0.0.1-SNAPSHOT</version><name>sentinel-demo</name><description>Demo project for Spring Boot</description><properties><java.version>1.8</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></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><exclusions><exclusion><groupId>org.junit.vintage</groupId><artifactId>junit-vintage-engine</artifactId></exclusion></exclusions></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId><version>2.1.0.RELEASE</version></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>

接着写个TestController来测试sentinel

package com.example.sentineldemo.api;import com.alibaba.csp.sentinel.annotation.SentinelResource;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
public class TestController {@GetMapping(value = "/hello")// 定义需要限流的资源名称为hello@SentinelResource("hello")public String hello() {return "Hello Sentinel";}
}

其中,@SentinelResource注解用来标识资源是否被限流、降级。上述例子上该注解的属性 'hello' 表示资源名。

@SentinelResource 还提供了其它额外的属性如 blockHandlerblockHandlerClassfallback 用于表示限流或降级的操作,更多内容可以参考 Sentinel注解支持。

OK,到这里最简单的Sentinel使用已经完成了。

3、Sentinel Dashboard

Sentinel 控制台提供一个轻量级的控制台,它提供机器发现、单机资源实时监控、集群资源汇总,以及规则管理的功能。您只需要对应用进行简单的配置,就可以使用这些功能。

注意: 集群资源汇总仅支持 500 台以下的应用集群,有大概 1 - 2 秒的延时。

如何使用Sentinel Dashboard?

  • 从 https://github.com/alibaba/Sentinel/releases 界面下载Sentinel Dashboard的jar包
  • Sentinel 控制台是一个标准的 SpringBoot 应用,以 SpringBoot 的方式运行 jar 包即可。运行如下命令:
    java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar
  • 配置项目的application.yml
    spring:cloud:sentinel:transport:dashboard: localhost:8080port: 8719
    server:port: 8081
    

    这里的 spring.cloud.sentinel.transport.port 端口配置会在应用对应的机器上启动一个 Http Server,该 Server 会与 Sentinel 控制台做交互。比如 Sentinel 控制台添加了1个限流规则,会把规则数据 push 给这个 Http Server 接收,Http Server 再将规则注册到 Sentinel 中。

4、运行

浏览器访问 http://localhost:8080/ ,会跳转到 Sentinel Dashboard 的login界面,默认的用户名及密码都是sentinel。登录成功后将跳转到sentinel home 界面。

sentinel home page

接着我们访问之前学好的hello api,http://localhost:8081/hello,在Sentinel Dashboard 可以看到

hello QPS

现在我们配置一个流控规则

配置流控规则

这里我们限制QPS单机阀值为2,结果如下

流控规则结果

接着,我们不断访问 http://localhost:8081/hello,在Sentinel Dashboard 可以看到

QPS

到此,Sentinel入门已经完成了???。

Learn More

Sentinel 官方文档

Sentinel 控制台 官方文档

Spring Cloud Alibaba Sentinel

 

  相关解决方案