【Spring Cloud Alibaba Sentinel 实现熔断与限流】 —— 每天一点小知识(上)

简介: 【Spring Cloud Alibaba Sentinel 实现熔断与限流】 —— 每天一点小知识

🐳Spring Cloud Alibaba Sentinel 实现熔断与限流

1. Sentinel概念

Sentinel是一款开源的流量控制组件,它提供了熔断、限流、降级等功能,可以保护微服务架构中的系统免受高并发请求的影响。在本篇博客中,我们将介绍如何使用Spring Cloud Alibaba Sentinel来实现熔断与限流。

2. 安装Sentinel控制台

Sentinel控制台是一个用于配置和管理Sentinel规则的可视化工具。在开始之前,我们需要先安装Sentinel控制台。

2.1 下载Sentinel控制台

💧在你的开发环境中选择一个合适的目录,执行以下命令下载Sentinel控制台:

git clone https://github.com/alibaba/Sentinel.git
cd Sentinel

2.2 编译与运行

💧进入Sentinel控制台目录,执行以下命令进行编译:

./mvnw clean package

编译完成后,执行以下命令启动Sentinel控制台:

java -jar sentinel-dashboard/target/sentinel-dashboard.jar

2.3 访问控制台

💧在浏览器中访问http://localhost:8080,你应该能够看到Sentinel控制台的登录页面。默认的用户名和密码都是sentinel

3. 初始化演示工程

💧为了演示Sentinel的熔断与限流功能,我们需要创建一个简单的Spring Cloud Alibaba工程。

3.1 创建工程

💧使用你习惯的方式创建一个新的Spring Cloud Alibaba工程,可以使用Spring Initializr或手动创建。

3.2 添加依赖

💧pom.xml文件中添加以下依赖:

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

3.3 配置文件

💧application.properties文件中添加以下配置:

# Sentinel控制台配置
spring.cloud.sentinel.transport.dashboard=localhost:8080
# 服务名称
spring.application.name=sentinel-demo

💧localhost:8080替换为你运行Sentinel控制台的地址和端口。

3.4 创建示例接口

💧创建一个简单的REST接口,用于演示Sentinel的熔断与限流功能。在一个新建的DemoController类中,添加以下代码:

@RestController
public class DemoController {
    @GetMapping("/hello")
    @SentinelResource("hello")
    public String hello() {
        return "Hello, Sentinel!";
    }
}

@SentinelResource("hello")注解表示该接口受Sentinel保护,限制其访问频率。

3.5 启动工程

💧运行工程,确保工程能够成功启动。

4. 流控规则

💧在Sentinel控制台中,我们可以配置流控规则,以限制对受保护资源的访问频率。

4.1 创建流控规则

💧在Sentinel控制台中,点击左侧导航栏的"流控规则",然后点击右上角的"新增"按钮。

💧在弹出的对话框中,填写规则信息。例如,我们设置一个QPS阈值为10的规则。

4.2 验证流控规则

💧在浏览器中访问http://localhost:8080/hello,你将看到接口返回的数据。继续刷新页面,当访问超过流控规则中设置的QPS阈值时,将会触发限流,接口将无法正常访问。

5. 服务降级

💧除了限流功能,Sentinel还提供了服务降级的功能,以应对异常情况下的服务调用。

5.1 创建降级规则

💧在Sentinel控制台中,点击左侧导航栏的"降级规则",然后点击右上角的"新增"按钮。

💧在弹出的对话框中,填写规则信息。例如,我们设置一个异常比例阈值为0.5的规则,即当接口调用的异常比例超过50%时,将触发降级。

5.2 验证降级规则

💧在浏览器中访问http://localhost:8080/hello,你将看到接口返回的数据。在代码中,我们可以通过抛出异常来模拟服务调用失败的情况。

💧继续访问接口,并观察接口的返回结果。当接口调用的异常比例超过降级规则中设置的阈值时,接口将会返回降级的结果。

【Spring Cloud Alibaba Sentinel 实现熔断与限流】 —— 每天一点小知识(下):https://developer.aliyun.com/article/1390083?spm=a2c6h.13148508.setting.23.4fea4f0ervlqra

相关文章
|
3天前
|
消息中间件 负载均衡 Java
【Spring Cloud 初探幽】
【Spring Cloud 初探幽】
13 1
|
5天前
|
Java 开发者 微服务
Spring Cloud原理详解
【5月更文挑战第4天】Spring Cloud是Spring生态系统中的微服务框架,包含配置管理、服务发现、断路器、API网关等工具,简化分布式系统开发。核心组件如Eureka(服务发现)、Config Server(配置中心)、Ribbon(负载均衡)、Hystrix(断路器)、Zuul(API网关)等。本文讨论了Spring Cloud的基本概念、核心组件、常见问题及解决策略,并提供代码示例,帮助开发者更好地理解和实践微服务架构。此外,还涵盖了服务通信方式、安全性、性能优化、自动化部署、服务网格和无服务器架构的融合等话题,揭示了微服务架构的未来趋势。
29 6
|
9天前
|
JSON Java Apache
Spring Cloud Feign 使用Apache的HTTP Client替换Feign原生httpclient
Spring Cloud Feign 使用Apache的HTTP Client替换Feign原生httpclient
|
9天前
|
负载均衡 Java 开发者
Spring Cloud:一文读懂其原理与架构
Spring Cloud 是一套微服务解决方案,它整合了Netflix公司的多个开源框架,简化了分布式系统开发。Spring Cloud 提供了服务注册与发现、配置中心、消息总线、负载均衡、熔断机制等工具,让开发者可以快速地构建一些常见的微服务架构。
|
11天前
|
消息中间件 Java RocketMQ
Spring Cloud RocketMQ:构建可靠消息驱动的微服务架构
【4月更文挑战第28天】消息队列在微服务架构中扮演着至关重要的角色,能够实现服务之间的解耦、异步通信以及数据分发。Spring Cloud RocketMQ作为Apache RocketMQ的Spring Cloud集成,为微服务架构提供了可靠的消息传输机制。
27 1
|
11天前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo: 微服务通信的高效解决方案
【4月更文挑战第28天】在微服务架构的发展中,服务间的高效通信至关重要。Spring Cloud Dubbo 提供了一种基于 RPC 的通信方式,使得服务间的调用就像本地方法调用一样简单。本篇博客将探讨 Spring Cloud Dubbo 的核心概念,并通过具体实例展示其在项目中的实战应用。
14 2
|
11天前
|
监控 Java Sentinel
Spring Cloud Sentinel:概念与实战应用
【4月更文挑战第28天】在分布式微服务架构中,确保系统的稳定性和可靠性至关重要。Spring Cloud Sentinel 为微服务提供流量控制、熔断降级和系统负载保护,有效预防服务雪崩。本篇博客深入探讨 Spring Cloud Sentinel 的核心概念,并通过实际案例展示其在项目中的应用。
22 0
|
11天前
|
Cloud Native Java Nacos
Spring Cloud Nacos:概念与实战应用
【4月更文挑战第28天】Spring Cloud Nacos 是一个基于 Spring Cloud 构建的服务发现和配置管理工具,适用于微服务架构。Nacos 提供了动态服务发现、服务配置、服务元数据及流量管理等功能,帮助开发者构建云原生应用。
18 0
|
14天前
|
Java 数据安全/隐私保护 Sentinel
微服务学习 | Spring Cloud 中使用 Sentinel 实现服务限流
微服务学习 | Spring Cloud 中使用 Sentinel 实现服务限流