【仿12306项目】基于SpringCloud,使用Sentinal对抢票业务进行限流
文章目录
- 一. 常见的限流算法
- 1. 静态窗口限流
- 2. 动态窗口限流
- 3. 漏桶限流
- 4. 令牌桶限流
- 5. 令牌大闸
- 二. Sentinal简介
- 三. 代码演示
- 0. 限流场景
- 1. 引入依赖
- 2. 定义资源
- 3. 定义规则
- 4. 启动测试
- 四. 使用Sentinel控台监控流量
- 1. Sentinel控台1.8.6版本下载地址
- 2. 文档说明:
- 3. 启动控制台
- 4. 客户端代码配置连接控制台
- 五. 使用Sentinel控制台配置接口限流
- 六. Sentinel+Nacos实现限流规则持久化
- 1. 添加依赖
- 2. 增加配置
- 3. Nacos增加流控规则
- 4. 控制台查看
- 七. 熔断简介
一. 常见的限流算法
方法的具体介绍由AI生成
1. 静态窗口限流
- 工作原理:
将时间划分为固定大小的窗口,例如每秒一个窗口。在每个窗口内,限制请求的总数。当窗口内的请求数量达到设定的阈值时,后续的请求将被拒绝,直到下一个窗口开始。 - 优点:
- 实现简单,容易理解和部署。
- 能够严格控制单位时间内的请求数量,避免系统过载。
- 缺点:
- 粒度较粗,容易出现“突发流量”问题。例如,如果一个窗口的请求刚好用完,而下一个窗口的请求又集中在窗口开始的瞬间,会导致流量的瞬间激增,对系统造成冲击。
- 不够灵活,无法根据实际流量动态调整窗口大小或阈值。
2. 动态窗口限流
- 工作原理:
在静态窗口的基础上引入动态调整机制。根据系统的实时负载情况(如CPU使用率、内存占用等),动态调整窗口的大小或阈值。例如,当系统负载较高时,减小窗口阈值;当系统负载较低时,适当增加窗口阈值。 - 优点:
- 比静态窗口限流更灵活,能够根据系统负载动态调整,更好地适应不同的流量情况。
- 能够在一定程度上缓解突发流量对系统的影响。
- 缺点:
- 实现相对复杂,需要实时监控系统的负载情况并进行动态调整。
- 动态调整的策略需要精心设计,否则可能会导致系统抖动或调整不及时。
3. 漏桶限流
- 工作原理:
漏桶算法的核心是一个“漏桶”,它以固定速率流出水(处理请求),而流入水(请求到达)的速率是不可控的。如果流入的水过多,导致桶溢出,多余的水(请求)将被丢弃。漏桶算法通过限制流出水的速率,来控制请求的处理速率。 - 优点:
- 能够平滑突发流量,将突发的请求分散到后续的时间中处理。
- 实现相对简单,容易理解。
- 缺点:
- 由于漏桶的流出速率是固定的,因此对突发流量的处理能力有限。如果突发流量过大,可能会导致大量请求被丢弃。
- 对于短时间内的高并发请求,响应速度可能会较慢,因为漏桶需要按照固定速率逐步处理。
4. 令牌桶限流
- 工作原理:
令牌桶算法的核心是一个“令牌桶”,系统以固定速率向桶中添加令牌。当请求到达时,会尝试从桶中获取令牌。如果桶中有令牌,则获取成功,请求被处理;如果桶中没有令牌,则请求被拒绝。令牌桶算法允许在短时间内处理突发流量,只要桶中有足够的令牌。 - 优点:
- 能够很好地处理突发流量,允许在短时间内处理更多的请求,只要令牌足够。
- 灵活性较高,可以通过调整令牌的生成速率和桶的容量来适应不同的场景。
- 缺点:
- 如果突发流量过大,可能会导致令牌桶中的令牌快速耗尽,后续的请求将被拒绝。
- 实现相对复杂,需要管理令牌的生成和消耗。
5. 令牌大闸
- 工作原理:
- 令牌大闸限流是一种相对较新的限流算法,其核心思想是通过“大闸”来控制流量。大闸会根据系统的负载情况和流量特征,动态地决定是否允许请求通过。它通常结合了多种策略,如令牌桶、动态窗口等,以实现更灵活的限流效果。例如,当系统负载较低时,大闸可以适当放宽限制;当系统负载较高时,大闸会严格限制流量。
- 优点:
- 集成了多种限流策略的优点,能够更灵活地应对复杂的流量场景。
- 能够根据系统的实时状态动态调整限流策略,避免系统过载。
- 缺点:
- 实现复杂度较高,需要综合考虑多种因素和策略。
- 配置和调优较为复杂,需要根据具体场景进行精细调整。
二. Sentinal简介
- 官网:https://sentinelguard.io/zh-cn/index.html
Sentinel 是阿里巴巴开源的分布式系统流量控制和熔断降级组件,通过流量控制、熔断降级、系统负载保护等功能,帮助微服务在高并发场景下保持稳定运行。它基于责任链模式设计,通过多个插槽(Slot)协同工作,实现流量监控、规则判断、资源降级等操作。Sentinel 提供可视化的控制台,方便用户实时监控系统状态并动态配置规则,同时支持与 Spring Cloud、Dubbo 等主流微服务框架无缝集成,广泛应用于分布式系统架构中,保障系统的高可用性。
重点:限流是做在被调用方,熔断是做在调用方
三. 代码演示
0. 限流场景
在基于SpringCloud的仿12306项目中,对于抢票这一环节需要做限流。对于关键业务doConfirm方法,进行限流访问。
1. 引入依赖
引入SpringCloud的sentinel依赖
<!-- 限流熔断 --><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId></dependency>
2. 定义资源
定义限流的内容,就是资源
@SentinelResource(value = "doConfirm", blockHandler = "doConfirmBlock")public void doConfirm(ConfirmOrderDoReq req) {// 业务代码}/*** 降级方法,需包含限流方法的所有参数和BlockException参数* @param req* @param e*/public void doConfirmBlock(ConfirmOrderDoReq req, BlockException e) {LOG.info("购票请求被限流:{}", req);throw new BusinessException(BusinessExceptionEnum.CONFIRM_ORDER_FLOW_EXCEPTION);}
blockHandler = “doConfirmBlock” 表示被阻塞之后调用doConfirmBlock方法
3. 定义规则
在启动类定义并调用规则:
@SpringBootApplication
@ComponentScan("com.mystudy")
@MapperScan("com.mystudy.train.*.mapper")
@EnableFeignClients("com.mystudy.train.business.feign")
@EnableCaching
public class BusinessApplication {private static final Logger LOG = LoggerFactory.getLogger(BusinessApplication.class);public static void main(String[] args) {SpringApplication app = new SpringApplication(BusinessApplication.class);Environment env = app.run(args).getEnvironment();LOG.info("启动成功!!");LOG.info("测试地址: \thttp://127.0.0.1:{}{}/test", env.getProperty("server.port"), env.getProperty("server.servlet.context-path"));// 限流规则initFlowRules();LOG.info("已定义限流规则");}// 定义限流规则private static void initFlowRules(){List<FlowRule> rules = new ArrayList<>();FlowRule rule = new FlowRule();rule.setResource("doConfirm");rule.setGrade(RuleConstant.FLOW_GRADE_QPS);// Set limit QPS to 20.rule.setCount(1);rules.add(rule);FlowRuleManager.loadRules(rules);}
}
4. 启动测试
通过JMeter测试,启动十个线程同时抢票,运行结束后,查看限流情况:

控制台打印,被拦截的请求有8个,说明成功限流。
还有2个请求成功进入业务代码,是因为每秒只允许1个请求进入,运行时间超过1秒
四. 使用Sentinel控台监控流量
1. Sentinel控台1.8.6版本下载地址
https://github.com/alibaba/Sentinel/releases/download/1.8.6/sentinel-dashboard-1.8.6.jar
2. 文档说明:
https://sentinelguard.io/zh-cn/docs/dashboard.html
3. 启动控制台
命令行运行:
java -Dserver.port=18080 -Dcsp.sentinel.dashboard.server=localhost:18080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.6.jar
访问浏览器:http://localhost:18080/
默认用户名密码均是
sentinel

4. 客户端代码配置连接控制台
- 增加配置:
# sentinel控台:https://github.com/alibaba/spring-cloud-alibaba/wiki/Sentinel
spring.cloud.sentinel.transport.port=8719
spring.cloud.sentinel.transport.dashboard=localhost:18080
18080端口与上述启动的端口要一致
连接完成后,只有当business模块有流量时,才会在控制台显示
- 控制台显示

控制台成功显示流量信息
- 同时可以在控制台查看限流规则,删除修改或者新增:

五. 使用Sentinel控制台配置接口限流
有了控制台,就不需要把流控规则写死在代码里了,可以利用控制台中的簇点链路来增加规则:
同时在对应的接口或者方法上增加相对应的注解,定义为资源
@SentinelResource(value = "xxx", blockHandler = "doConfirmBlock")
这样就可以设置动态流控策略了!
六. Sentinel+Nacos实现限流规则持久化
上述在控制台修改流控策略的方法,在服务器重启之后会消失,不能实现持久化,因此可以使用Sentinel+Nacos实现限流规则持久化
1. 添加依赖
<!-- sentinel + nacos --><dependency><groupId>com.alibaba.csp</groupId><artifactId>sentinel-datasource-nacos</artifactId></dependency>
2. 增加配置
# sentinel + nacos
spring.cloud.sentinel.datasource.flow.nacos.serverAddr=127.0.0.1:8848
spring.cloud.sentinel.datasource.flow.nacos.namespace=train
spring.cloud.sentinel.datasource.flow.nacos.groupId=DEFAULT_GROUP
spring.cloud.sentinel.datasource.flow.nacos.dataId=sentinel-business-flow
spring.cloud.sentinel.datasource.flow.nacos.ruleType=flow
3. Nacos增加流控规则

[{"resource": "doConfirm","limitApp": "default","grade": 1,"count": 100,"strategy": 0,"controlBehavior": 0,"clusterMode": false}
]
4. 控制台查看

此时就有持久化配置项了
七. 熔断简介
熔断是一种容错机制,用于防止分布式系统中的雪崩效应。当某个服务或资源出现故障(如响应时间过长、错误率过高)时,熔断器会快速失败并停止对该服务的调用,避免故障扩散到整个系统。经过一段时间后,熔断器会尝试恢复调用,如果问题已解决,则恢复正常调用。
相关文章:
【仿12306项目】基于SpringCloud,使用Sentinal对抢票业务进行限流
文章目录 一. 常见的限流算法1. 静态窗口限流2. 动态窗口限流3. 漏桶限流4. 令牌桶限流5. 令牌大闸 二. Sentinal简介三. 代码演示0. 限流场景1. 引入依赖2. 定义资源3. 定义规则4. 启动测试 四. 使用Sentinel控台监控流量1. Sentinel控台1.8.6版本下载地址2. 文档说明…...
【赵渝强老师】Spark RDD的依赖关系和任务阶段
Spark RDD彼此之间会存在一定的依赖关系。依赖关系有两种不同的类型:窄依赖和宽依赖。 窄依赖:如果父RDD的每一个分区最多只被一个子RDD的分区使用,这样的依赖关系就是窄依赖;宽依赖:如果父RDD的每一个分区被多个子RD…...
【B站保姆级视频教程:Jetson配置YOLOv11环境(六)PyTorchTorchvision安装】
Jetson配置YOLOv11环境(6)PyTorch&Torchvision安装 文章目录 1. 安装PyTorch1.1安装依赖项1.2 下载torch wheel 安装包1.3 安装 2. 安装torchvisiion2.1 安装依赖2.2 编译安装torchvision2.2.1 Torchvisiion版本选择2.2.2 下载torchvisiion到Downloa…...
Verilog语言学习总结
Verilog语言学习! 目录 文章目录 前言 一、Verilog语言是什么? 1.1 Verilog简介 1.2 Verilog 和 C 的区别 1.3 Verilog 学习 二、Verilog基础知识 2.1 Verilog 的逻辑值 2.2 数字进制 2.3 Verilog标识符 2.4 Verilog 的数据类型 2.4.1 寄存器类型 2.4.2 …...
【阅读笔记】LED显示屏非均匀度校正
一、背景 发光二极管(LED)显示屏具有色彩鲜艳、图像清晰、亮度高、驱动电压低、功耗小、耐震动、价格低廉和使用寿命长等优势。LED显示图像的非均匀度是衡量LED显示屏显示质量的指标,非均匀度过高,会导致LED显示图像出现明暗不均…...
【Java异步编程】CompletableFuture基础(1):创建不同线程的子任务、子任务链式调用与异常处理
文章目录 1. 三种实现接口2. 链式调用:保证链的顺序性与异步性3. CompletableFuture创建CompletionStage子任务4. 处理异常a. 创建回调钩子b. 调用handle()方法统一处理异常和结果 5. 如何选择线程池:不同的业务选择不同的线程池 CompletableFuture是JDK…...
ESXI虚拟机中部署docker会降低服务器性能
在 8 核 16GB 的 ESXi 虚拟机中部署 Docker 的性能影响分析 在 ESXi 虚拟机中运行 Docker 容器时,性能影响主要来自以下几个方面: 虚拟化开销:ESXi 虚拟化层和 Docker 容器化层的叠加。资源竞争:虚拟机与容器之间对 CPU、内存、…...
ASP.NET Core与配置系统的集成
目录 配置系统 默认添加的配置提供者 加载命令行中的配置。 运行环境 读取方法 User Secrets 注意事项 Zack.AnyDBConfigProvider 案例 配置系统 默认添加的配置提供者 加载现有的IConfiguration。加载项目根目录下的appsettings.json。加载项目根目录下的appsettin…...
中间件的概念及基本使用
什么是中间件 中间件是ASP.NET Core的核心组件,MVC框架、响应缓存、身份验证、CORS、Swagger等都是内置中间件。 广义上来讲:Tomcat、WebLogic、Redis、IIS;狭义上来讲,ASP.NET Core中的中间件指ASP.NET Core中的一个组件。中间件…...
SpringBoot 整合 Mybatis:注解版
第一章:注解版 导入配置: <groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId><version>1.3.1</version> </dependency> 步骤: 配置数据源见 Druid…...
18.[前端开发]Day18-王者荣耀项目实战(一)
01-06 项目实战 1 代码规范 2 CSS编写顺序 3 组件化开发思想 组件化开发思路 项目整体思路 – 各个击破 07_(掌握)王者荣耀-top-整体布局完成 完整代码 01_page_top1.html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8…...
Kafka 使用说明(kafka官方文档中文)
文章来源:kafka -- 南京筱麦软件有限公司 第 1 步:获取 KAFKA 下载最新的 Kafka 版本并提取它: $ tar -xzf kafka_{{scalaVersion}}-{{fullDotVersion}}.tgz $ cd kafka_{{scalaVersion}}-{{fullDotVersion}} 第 2 步:启动 KAFKA 环境 注意:您的本地环境必须安装 Java 8+。…...
基于多智能体强化学习的医疗AI中RAG系统程序架构优化研究
一、引言 1.1 研究背景与意义 在数智化医疗飞速发展的当下,医疗人工智能(AI)已成为提升医疗服务质量、优化医疗流程以及推动医学研究进步的关键力量。医疗 AI 借助机器学习、深度学习等先进技术,能够处理和分析海量的医疗数据,从而辅助医生进行疾病诊断、制定治疗方案以…...
Airflow:深入理解Apache Airflow Task
Apache Airflow是一个开源工作流管理平台,支持以编程方式编写、调度和监控工作流。由于其灵活性、可扩展性和强大的社区支持,它已迅速成为编排复杂数据管道的首选工具。在这篇博文中,我们将深入研究Apache Airflow 中的任务概念,探…...
multisim入门学习设计电路
文章目录 1.软件的安装2.电路基本设计2.1二极管的简介2.2最终的设计效果2.3设计流程介绍 3.如何测试电路 1.软件的安装 我是参考的下面的这个文章,文章的链接放在下面,亲测是有效的,如果是小白的话,可以参考一下: 【…...
【算法精练】二分查找算法总结
目录 前言 1. 二分查找(基础版) 2. 寻找左右端点 循环判断条件 求中间点 总结 前言 说起二分查找,也是一种十分常见的算法,最常听说的就是:二分查找只能在数组有序的场景下使用;其实也未必,…...
从零开始实现一个双向循环链表:C语言实战
文章目录 1链表的再次介绍2为什么选择双向循环链表?3代码实现:从初始化到销毁1. 定义链表节点2. 初始化链表3. 插入和删除节点4. 链表的其他操作5. 打印链表和判断链表是否为空6. 销毁链表 4测试代码5链表种类介绍6链表与顺序表的区别7存储金字塔L0: 寄存…...
MYSQL面试题总结(题目来源JavaGuide)
MYSQL基础架构 问题1:一条 SQL语句在MySQL中的执行过程 1. 解析阶段 (Parsing) 查询分析:当用户提交一个 SQL 语句时,MySQL 首先会对语句进行解析。这个过程会检查语法是否正确,确保 SQL 语句符合 MySQL 的语法规则。如果发现…...
visual studio安装
一、下载Visual Studio 访问Visual Studio官方网站。下载 Visual Studio Tools - 免费安装 Windows、Mac、Linux 在主页上找到并点击“下载 Visual Studio”按钮。 选择适合需求的版本,例如“Visual Studio Community”(免费版本)&#x…...
JVM执行引擎
一、执行引擎的概述: 执行引擎是]ava虚拟机核心的组成部分之一; “虚拟机”是一个相对于“物理机”的概念,这两种机器都有代码执行能力,其区别是物理机的执行引擎是直接建立在处理器、缓存、指令集和操作系统层面上的,而虚拟机的执行引擎则…...
CMake基础:构建流程详解
目录 1.CMake构建过程的基本流程 2.CMake构建的具体步骤 2.1.创建构建目录 2.2.使用 CMake 生成构建文件 2.3.编译和构建 2.4.清理构建文件 2.5.重新配置和构建 3.跨平台构建示例 4.工具链与交叉编译 5.CMake构建后的项目结构解析 5.1.CMake构建后的目录结构 5.2.构…...
如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
postgresql|数据库|只读用户的创建和删除(备忘)
CREATE USER read_only WITH PASSWORD 密码 -- 连接到xxx数据库 \c xxx -- 授予对xxx数据库的只读权限 GRANT CONNECT ON DATABASE xxx TO read_only; GRANT USAGE ON SCHEMA public TO read_only; GRANT SELECT ON ALL TABLES IN SCHEMA public TO read_only; GRANT EXECUTE O…...
微信小程序云开发平台MySQL的连接方式
注:微信小程序云开发平台指的是腾讯云开发 先给结论:微信小程序云开发平台的MySQL,无法通过获取数据库连接信息的方式进行连接,连接只能通过云开发的SDK连接,具体要参考官方文档: 为什么? 因为…...
华为OD机考-机房布局
import java.util.*;public class DemoTest5 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseSystem.out.println(solve(in.nextLine()));}}priv…...
BLEU评分:机器翻译质量评估的黄金标准
BLEU评分:机器翻译质量评估的黄金标准 1. 引言 在自然语言处理(NLP)领域,衡量一个机器翻译模型的性能至关重要。BLEU (Bilingual Evaluation Understudy) 作为一种自动化评估指标,自2002年由IBM的Kishore Papineni等人提出以来,…...
掌握 HTTP 请求:理解 cURL GET 语法
cURL 是一个强大的命令行工具,用于发送 HTTP 请求和与 Web 服务器交互。在 Web 开发和测试中,cURL 经常用于发送 GET 请求来获取服务器资源。本文将详细介绍 cURL GET 请求的语法和使用方法。 一、cURL 基本概念 cURL 是 "Client URL" 的缩写…...
rknn toolkit2搭建和推理
安装Miniconda Miniconda - Anaconda Miniconda 选择一个 新的 版本 ,不用和RKNN的python版本保持一致 使用 ./xxx.sh进行安装 下面配置一下载源 # 清华大学源(最常用) conda config --add channels https://mirrors.tuna.tsinghua.edu.cn…...
倒装芯片凸点成型工艺
UBM(Under Bump Metallization)与Bump(焊球)形成工艺流程。我们可以将整张流程图分为三大阶段来理解: 🔧 一、UBM(Under Bump Metallization)工艺流程(黄色区域ÿ…...
【若依】框架项目部署笔记
参考【SpringBoot】【Vue】项目部署_no main manifest attribute, in springboot-0.0.1-sn-CSDN博客 多一个redis安装 准备工作: 压缩包下载:http://download.redis.io/releases 1. 上传压缩包,并进入压缩包所在目录,解压到目标…...
