黑人与白人做爰网站/武汉网站设计
文章目录
- 一. 常见的限流算法
- 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虚拟机核心的组成部分之一; “虚拟机”是一个相对于“物理机”的概念,这两种机器都有代码执行能力,其区别是物理机的执行引擎是直接建立在处理器、缓存、指令集和操作系统层面上的,而虚拟机的执行引擎则…...

C# 9.0记录类型:解锁开发效率的魔法密码
一、引言:记录类型的神奇登场 在 C# 的编程世界中,数据结构就像是构建软件大厦的基石,其重要性不言而喻。然而,传统的数据结构定义方式,尤其是在处理简单的数据承载对象时,常常显得繁琐复杂。例如…...

搭建自己的专属AI——使用Ollama+AnythingLLM+Python实现DeepSeek本地部署
前言 最近DeepSeek模型非常火,其通过对大模型的蒸馏得到的小模型可以较轻松地在个人电脑上运行,这也使得我们有机会在本地构建一个专属于自己的AI,进而把AI“调教”为我们希望的样子。本篇文章中我将介绍如何使用OllamaAnythingLLMPython实现…...

『 C++ 』中理解回调类型在 C++ 中的使用方式。
文章目录 案例 1:图形绘制库中的回调使用场景说明代码实现代码解释 案例 2:网络服务器中的连接和消息处理回调场景说明代码实现代码解释 案例 3:定时器中的回调使用场景说明代码实现代码解释 以下将通过不同场景给出几个使用回调类型的具体案…...

git多人协作
目录 一、项目克隆 二、 1、进入克隆仓库设置 2、协作处理 3、冲突处理 4、多人协作分支的推送拉取删除 1、分支推送(2种) 2、远程分支拉取(2种) 3、远程分支删除 一、项目克隆 git clone 画船听雨眠/test1 (自定义的名…...

CTFSHOW-WEB入门-命令执行71-77
题目:web 71 题目:解题思路:分析可知highlight_file() 函数被禁了,先想办法看看根目录:cvar_export(scandir(dirname(‘/’))); 尝试一下发现很惊奇:(全是?)这种情况我也…...

浅谈《图解HTTP》
感悟 滑至尾页的那一刻,内心突兀的涌来一阵畅快的感觉。如果说从前对互联网只是懵懵懂懂,但此刻却觉得她是如此清晰而可爱的呈现在哪里。 介绍中说,《图解HTTP》适合作为第一本网络协议书。确实,它就像一座桥梁,连接…...

LLMs瞬间获得视觉与听觉感知,无需专门训练:Meta的创新——在图像、音频和视频任务上实现最优性能。
引言: 问题: 当前的多模态任务(如图像、视频、音频描述生成、编辑、生成等)通常需要针对特定任务训练专门的模型,而现有的方法在跨模态泛化方面存在局限性,难以适应新任务。此外,多模态嵌入反演…...

自研有限元软件与ANSYS精度对比-Bar3D2Node三维杆单元模型-央视大裤衩实例
目录 1、“央视大裤衩”自研有限元软件求解 1.1、选择单元类型 1.2、导入“央视大裤衩”工程 1.3、节点坐标定义 1.4、单元连接关系、材料定义 1.5、约束定义 1.6、外载定义 1.7、矩阵求解 1.8、变形云图展示 1.9、节点位移 1.10、单元应力 1.11、节点支反力 2、“…...

kubernetes 高可用集群搭建
在生产环境中部署 Kubernetes 集群时,确保其高可用性(High Availability, HA)是至关重要的。高可用性不仅意味着减少服务中断时间,还能提高系统的稳定性和可靠性。本文将详细介绍如何搭建一个高可用的 Kubernetes 集群,…...

【C++】STL——vector底层实现
目录 💕 1.vector三个核心 💕2.begin函数,end函数的实现(简单略讲) 💕3.size函数,capacity函数的实现 (简单略讲) 💕4.reserve函数实现 (细节…...