SpringBoot轻松整合Sentinel限流

前言

Sentinel是阿里开源的用于服务器容错的综合解决方案,是一个面向分布式服务的轻量级的流控框架,它主要是以流量为切入点,从流量的控制、服务熔断降级、服务负载保护等方面来维护系统的稳定性。承载了阿里很多大型业务场景的核心处理逻辑,例如双十一的秒杀、消息处理、流量控制、实时服务熔断等场景。

Sentinel的核心分为两个部分:核心库(Java客户端),能够运行于所有Java运行时环境,同时对Dubbo/SpringCloud等框架也有较好的支持;以及控制台(Dashboard),基于SpringBoot开发,打包后可以直接运行。

下面我们就来看看Spring Boot应用中如何使用Sentinel实现服务限流操作。

安装Sentinel

下载

可以从Sentinel的GitHub地址进行下载;

https://github.com/alibaba/Sentinel/releases

解压

下载完成之后,解压对应的压缩包到指定的路径下。

运行

在Linux系统中可以通过如下的命令来启动

复制代码
./start.sh

启动之后,可以访问浏览器的http://localhost:8080地址来查看Sentinel控制台。如下所示。

在控制台中,你可以根据需要配置流控规则、降级规则、系统规则等,以实现对应用程序的监控和流量控制。

添加POM依赖

在你的Spring Boot项目中添加Sentinel的依赖。你可以在pom.xml文件中添加以下依赖:

复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

配置Sentinel

application.yml中配置Sentinel的相关信息,例如:

复制代码
spring.cloud.sentinel.transport.port=8719
spring.cloud.sentinel.transport.dashboard=127.0.0.1:8080

这里配置了Sentinel的控制台地址为127.0.0.1:8080,用于监控和管理限流规则。

定义限流的规则

在Sentinel控制台中定义限流规则,可以定义URL、资源名、流控模式、阈值等限流参数。这里就不做详细介绍了。

使用限流操作

在需要进行限流的方法上添加**@SentinelResource**注解,代码如下:

复制代码
@RestController
public class MyController {

    @GetMapping("/test")
    @SentinelResource(value = "test", blockHandler = "handleBlock")
    public String test() {
        // Your business logic here
        return "Test API";
    }

    // Block handler for handling blocked requests
    public String handleBlock(BlockException ex) {
        return "Blocked due to flow control";
    }
}

在上面这个例子中test接口上被添加了**@SentinelResource,**并且指定了限流的资源名称,以及限流的执行策略,并且在下面的内容中添加了处理策略,当然也可以指定统一拒绝策略。这个可以根据具体的业务场景来定。

项目启动之后,可以调用指定的接口来看看接口的限流策略配置执行情况。

相关推荐
q***46522 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
努力发光的程序员2 小时前
互联网大厂Java面试:从Spring Boot到大数据处理的实战场景问题解析
spring boot·微服务·云原生·java面试·大数据处理·技术解析·互联网求职
Li_7695322 小时前
10分钟快速入手Spring Cloud Config
java·spring·spring cloud
源码技术栈2 小时前
Java基于云计算的社区门诊系统源码 医院门诊系统源码 已实现医保结算 SaaS模式
java·云计算·源码·诊所·门诊·预约挂号·云门诊
三七互娱后端团队2 小时前
告别“玄学”调参:DSPy 框架入门,让 AI 自动优化 AI 的提示词
人工智能·后端
星星电灯猴2 小时前
iPhone 抓包工具怎么选?从 HTTPS 调试、TCP 数据流分析到多工具协同的完整方案
后端
程序员西西2 小时前
SpringBoot整合JWT实现安全认证
java·计算机·程序员·编程
三七互娱后端团队2 小时前
别再只用 Vector Search 了:手把手教你落地 GraphRAG(图谱增强检索)
人工智能·后端
南雨北斗2 小时前
Kotlin中遍历集合的方法
后端