【Sentinel的限流使用】⭐️SpringBoot整合Sentinel实现Api的限流
目录
前言
一、Sentinel下载
二、SpringBoot 整合 Sentinel
三、流控规则
章末
前言
小伙伴们大家好,上次使用OpenFeign时用到了 Hystrix实现熔断和限流的功能,但是发现该工具已经停止维护了,于是想到了Spring Cloud Alibaba开发的Sentinel工具,也可以实现流量控制,熔断降级,系统负载保护等
一、Sentinel下载
项目地址:Releases · alibaba/Sentinel · GitHub
1.直接下载 jar 包,到文件下载目录层级打开命令页面
2.使用 java -jar sentinel-dashboard-1.8.7.jar 启动sentinel
注:sentinel默认启动使用的是 8080 端口,如果担心被占用可以指定端口号
java -jar sentinel-dashboard-1.8.7.jar --server.port=8333
3.访问管理页面
访问 http://localhost:8333/#/login ,进到登陆页面,默认登陆用户密码都是sentinel
二、SpringBoot 整合 Sentinel
2.1 引入依赖
我这里制定了版本,因为用的父依赖中没有引用
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId><version>2.1.3.RELEASE</version></dependency>
2.2 配置信息
spring:...cloud:sentinel:transport:#控制台地址配置dashboard: localhost:8333#传输端口port: 8719#暴露所有的端点
management:endpoints:web:exposure:include: "*"
2.3 启动类开启服务发现
在启动类上加 @EnableDiscoveryClient 注解,打开服务发现功能
2.4 测试接口加注解@SentinelResource
@SentinelResource@PostMapping(value = "/login")public BaseResult login(String username, String password) {UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));...return BaseResult.success();}
2.5 启动项目
注:本地启动项目连接控制台后,发现看不到服务,可能是因为 Sentinel 本身懒加载的原因,就是说服务不被调用,sentinel 控制台是无法感知到服务的,需要手动调用一次接口刷新
检测到服务后的界面如下:
三、流控规则
3.1 基本介绍
资源名:唯一名称,默认的请求路径
针对来源:Sentinel 可以针对调用者进行限流,填写微服务名称,默认是default也就是不区分来源
阈值类型/单机阈值:
1.QPS 每秒钟的请求数量 : 当调用该api接口的QPS到达阈值时,启动限流
2.线程数:当调用该api的线程数达到阈值的时候,进行限流
是否集群:不需要集群
流控模式:挑默认的看下
1.直接: api达到限流条件时,直接限流
流控效果:
1.快速失败 : 直接失败,抛出异常
3.2 添加一个流控规则,限制单机阈值 QPS 为1
3.3 注意事项
在添加流控规则的时候,可能会遇到添加失败的场景,也就是点击添加后控制台上没有显示
产生原因:可能是客户端是否使用了低版本的 fastjson,低版本的 fastjson 可能会有此问题,建议使用和 Sentinel 相关组件一致版本的 fastjson。
解决方案: 我这里升级了 fastjson 的版本之后就可以正常添加了
<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.58</version></dependency>
3.4 测试接口
因为设置的是每秒支持一个请求,所以测试的时候简单实现只要快速点击请求即可实现,结果如下,因为QPS 设置为1,所以每次通过的只有一个,拒绝 QPS 指的就是被限流请求失败的,同时到控制台看下日志,也会打出限流导致的异常日志
章末
后续再补充熔断,负载的使用,以及搭配OpenFeign使用
好了,文章到这里就结束了~
后续虽迟但到
一、sentinel 的熔断降级
1.1、书接上文,替换 Hystrix 实现熔断降级,将 Hystrix 的配置项改为 false,另外添加 Sentinel 的配置并开启,如下图,测试下发现可以实现触发降级之后的操作,并且使用sentinel 控制台可以设置一系列的熔断操作
【远程调用✈️✈️】通过OpenFeign实现服务的远程调用,熔断降级等-CSDN博客
1.2、熔断规则,这里的参数配置分别代表如下:
熔断策略:
- 慢调用比例:根据一定的时间窗口内请求的响应时间超过设定阈值的比例来触发熔断。
例如:假设我们有一个服务,处理用户请求并返回结果。我们可以设置一个慢调用比例阈值,比如 0.5(50%)。这意味着如果有一段时间内超过一半的请求的响应时间超过了设定的阈值(比如 1秒),则触发熔断。这可以防止因为服务响应缓慢而影响整体系统性能。- 异常比例:根据一定的时间窗口内的请求异常比例来触发熔断。
例如:如果某个服务的异常比例突然升高,可能会导致整个系统的可用性下降。通过设置异常比例阈值,比如 0.5(50%),当一定时间内的异常请求比例超过这个阈值时,触发熔断,防止异常的服务影响到整个系统。- 异常数:根据一定的时间窗口内的异常次数来触发熔断。
例如:如果我们的服务处理了大量的异常请求,可能表明服务本身出现了问题。我们可以设置一个异常数阈值,比如每分钟超过 100 次异常请求,则触发熔断。这可以避免因为服务异常频繁而导致系统的崩溃。
最大 RT: 假设我们的服务要求在 500 毫秒内返回结果,但是由于某些原因,有些请求的响应时间超过了这个阈值。我们可以设置最大 RT 为 500 毫秒,当超过这个阈值时触发熔断,防止慢速请求占用系统资源。
熔断时长: 当熔断发生后,熔断器会进入一个打开状态,在熔断时长内拒绝所有请求。这个时长可以根据业务需求来设置,比如设置为 60 秒,表示熔断器打开后,需要等待 60 秒才能尝试恢复服务。
最小请求数: 在熔断器进入半开状态之前,需要满足一定数量的请求。比如设置最小请求数为 10,表示在尝试恢复服务之前,至少需要有 10 个请求经过熔断器。
统计时常: 统计时长用于计算慢调用比例、异常比例和异常数。比如设置统计时长为 1 分钟,则每分钟的请求数据将被用来判断是否触发熔断。
二、 sentinel 的热点规则
新增热点规则的参数如下:
资源:
- 资源是需要进行限流的具体接口、URL 或方法等标识符。你需要指定哪些资源需要应用热点规则。
参数索引:
- 参数对应的 controller 中方法参数的下标,就是指对哪个方法参数作为热点参数
QPS 阈值:
- QPS 阈值是指在一秒内允许通过的请求次数。当热点参数的访问频率超过该阈值时,将触发限流措施。
热点参数阈值:
- 热点参数阈值是针对热点参数的具体限流阈值。当热点参数的访问频率超过该阈值时,将触发限流。
统计时长:
- 统计时长是指统计数据的时间窗口大小,用于计算热点参数的访问频率。这个时间窗口内的请求数据将被用来判断是否触发限流。
例如:
登录接口限流:
- 资源:
/api/user/login(登录接口请求地址)
- 参数索引:用户名(指定登录接口方法中的用户名参数为热点参数)
- QPS 阈值:50
- 热点参数阈值:5
- 统计时长:1分钟
- 这个规则将限制每个用户名在一分钟内访问
/api/user/login
接口的频率不能超过 50 次,并且对于任何单个用户名,每秒最多只能有 5 次登录请求。
三、总结
不难发现,限流、熔断、热点等共同的特点就是在一个场景中,只要触发了我们提前配置好的限流策略,熔断降级,热点规则等条件,就会执行截断操作,放到代码层面来看就是相当于请求被拦截去执行指定方法,以达到对系统的保护,防止系统因过载崩溃,反过来,突发的流量激增,资源耗尽或者异常...就是请求拦截的各种场景,一旦预先配置的条件达到,就会执行相应的截断操作!
相关文章:

【Sentinel的限流使用】⭐️SpringBoot整合Sentinel实现Api的限流
目录 前言 一、Sentinel下载 二、SpringBoot 整合 Sentinel 三、流控规则 章末 前言 小伙伴们大家好,上次使用OpenFeign时用到了 Hystrix实现熔断和限流的功能,但是发现该工具已经停止维护了,于是想到了Spring Cloud Alibaba开发的Sentin…...

【示例】MySQL-SQL语句优化
前言 本文主要讲述不同SQL语句的优化策略。 SQL | DML语句 insert语句 插入数据的时候,改为批量插入 插入数据的时候,按照主键顺序插入 大批量插入数据的时候(百万),用load指令,从本地文件载入&#x…...
QT 线程的使用
1.头文件: #include<QThread> 2.在.h文件中定义全局: QThread* threadTraj; void threadTrajProcess();//回调函数 3.在.cpp文件中: threadTraj new QThread();//初始化 //连接槽函数 QObject::connect(threadTraj, &QThre…...

Python基于flask的豆瓣电影分析可视化系统
博主介绍:✌程序员徐师兄、7年大厂程序员经历。全网粉丝12w、csdn博客专家、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ 🍅文末获取源码联系🍅 👇🏻 精彩专栏推荐订阅👇…...

【迅为iTOP-4412-linux 系统制作(4)】ADB 或者 TF 卡烧写测试
准备工作 编译生成的内核镜像uImage 和设备树 dtb 文件“exynos4412-itop-elite.dtb”已经可以使用了。 把编译生成的uimage和dtb文件。拷贝fastboot工具。官方的u-boot-iTOP-4412.bin 也拷贝到 platform-tools 文件夹目录内。system.img 也拷贝到 platform-tools 文件夹目录…...
阿里云对象存储OSS批量上传,单个上传,批量删除,单个删除!
请自行替换秘钥: #阿里云 OSS src/main/resources/application.properties #不同的服务器,地址不同 aliyun.oss.file.endpointhttps://oss-cn-hangzhou.aliyuncs.com aliyun.oss.file.accessKeyIdLTAI5t9wUqCoD42qPGRy8S aliyun.oss.file.accessKeySecre…...

Python的国际化和本地化【第162篇—国际化和本地化】
👽发现宝藏 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。【点击进入巨牛的人工智能学习网站】。 随着全球化的发展,多语言支持在软件开发中变得越来越重要。Python作为一种流行的…...
播放Samba协议下的音视频文件
Samba(也被称为SMB/CIFS)是一个用于在局域网内共享文件和打印服务的协议,广泛应用于Windows和Linux系统之间的文件共享。 一、展示Samba服务器下的文件 使用如jcifs这样的Java库来在安卓应用中集成SMB/CIFS客户端功能。这个库提供了与SMB/CI…...

Excel全套213集教程
Excel全套213集教程 包含技术入门93集 图表17集 数据透视35集 公式函数68 基础入门 93节 https://www.alipan.com/s/cMxuPstkS1x 提取码: 77dd 点击链接保存,或者复制本段内容,打开「阿里云盘」APP ,无需下载极速在线查看,视…...

【七 (1)指标体系建设-构建高效的故障管理指标体系】
目录 文章导航一、故障概述1、故障:2、故障管理: 二、指标体系概述1、指标2、指标体系 三、指标体系构建难点1、管理视角2、业务视角3、技术视角 四、指标体系构建原则1、与战略目标对齐2、综合和平衡3、数据可获得性4、可操作性5、具体和可衡量6、参与和…...

Go gin框架(详细版)
目录 0. 为什么会有Go 1. 环境搭建 2. 单-请求&&返回-样例 3. RESTful API 3.1 首先什么是RESTful API 3.2 Gin框架支持RESTful API的开发 4. 返回前端代码 go.main index.html 5. 添加静态文件 main.go 改动的地方 index.html 改动的地方 style.css 改动…...

Git分布式版本控制系统——Git常用命令(二)
五、Git常用命令————分支操作 同一个仓库可以有多个分支,各个分支相互独立,互不干扰 分支的相关命令,具体如下: git branch 查看分支 git branch [name] 创建分支&#x…...

LeetCode 59.螺旋矩阵II
LeetCode 59.螺旋矩阵II 1、题目 力扣题目链接:59. 螺旋矩阵 II - 力扣(LeetCode) 给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。 示例 1࿱…...

03-JAVA设计模式-适配器模式
适配器模式 设么是适配器模式 它属于结构型模式,主要用于将一个类的接口转换成客户端所期望的另一种接口,从而使得原本由于接口不兼容而无法协同工作的类能够一起工作。 适配器模式主要解决的是不兼容接口的问题。在软件开发中,经常会有这…...

MVVM架构模式
目录 MVVM 数据绑定方式 实现方式 Model View ViewModel 数据绑定方式 vue:: 数据劫持和发布-订阅模式: Object.defineProperty() 方法来劫持(监控)各属性的 getter 、setter ,并在数据(对…...
leetcode2924--找到冠军II
1. 题意 给定一个有向无环图,方向表示胜负关系;求最后胜出的人。 2. 题解 将所有人标记为胜者,统计出度去掉对应胜者标记; 最后统计胜者数目,是否大于1,若大于1,则没有胜者,否则…...

嵌入式|蓝桥杯STM32G431(HAL库开发)——CT117E学习笔记13:RTC实时时钟
系列文章目录 嵌入式|蓝桥杯STM32G431(HAL库开发)——CT117E学习笔记01:赛事介绍与硬件平台 嵌入式|蓝桥杯STM32G431(HAL库开发)——CT117E学习笔记02:开发环境安装 嵌入式|蓝桥杯STM32G431(…...

统一用安卓Studio修改项目包名
可以逃跑,可以哭泣,但不可以放弃 --《鬼灭之刃》 修改项目包名 1)选中项目中药修改的包名: 2)目结构显示方式,取消 Compact Middle Packages 选项; 3)右键要修改的包名,选择 Refactor —— Re…...

Spring Cloud Gateway详细介绍以及实现动态路由
一. 简介 Spring Cloud Gateway This project provides a libraries for building an API Gateway on top of Spring WebFlux or Spring WebMVC. Spring Cloud Gateway aims to provide a simple, yet effective way to route to APIs and provide cross cutting concerns to …...
transformer上手(6)—— 微调预训练模型
1 加载数据集 以同义句判断任务为例(每次输入两个句子,判断它们是否为同义句),构建我们的第一个 Transformers 模型。我们选择蚂蚁金融语义相似度数据集 AFQMC 作为语料,它提供了官方的数据划分,训练集 / …...
Python爬虫实战:研究MechanicalSoup库相关技术
一、MechanicalSoup 库概述 1.1 库简介 MechanicalSoup 是一个 Python 库,专为自动化交互网站而设计。它结合了 requests 的 HTTP 请求能力和 BeautifulSoup 的 HTML 解析能力,提供了直观的 API,让我们可以像人类用户一样浏览网页、填写表单和提交请求。 1.2 主要功能特点…...

新能源汽车智慧充电桩管理方案:新能源充电桩散热问题及消防安全监管方案
随着新能源汽车的快速普及,充电桩作为核心配套设施,其安全性与可靠性备受关注。然而,在高温、高负荷运行环境下,充电桩的散热问题与消防安全隐患日益凸显,成为制约行业发展的关键瓶颈。 如何通过智慧化管理手段优化散…...

微服务商城-商品微服务
数据表 CREATE TABLE product (id bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 商品id,cateid smallint(6) UNSIGNED NOT NULL DEFAULT 0 COMMENT 类别Id,name varchar(100) NOT NULL DEFAULT COMMENT 商品名称,subtitle varchar(200) NOT NULL DEFAULT COMMENT 商…...
Unit 1 深度强化学习简介
Deep RL Course ——Unit 1 Introduction 从理论和实践层面深入学习深度强化学习。学会使用知名的深度强化学习库,例如 Stable Baselines3、RL Baselines3 Zoo、Sample Factory 和 CleanRL。在独特的环境中训练智能体,比如 SnowballFight、Huggy the Do…...

C# 求圆面积的程序(Program to find area of a circle)
给定半径r,求圆的面积。圆的面积应精确到小数点后5位。 例子: 输入:r 5 输出:78.53982 解释:由于面积 PI * r * r 3.14159265358979323846 * 5 * 5 78.53982,因为我们只保留小数点后 5 位数字。 输…...

短视频矩阵系统文案创作功能开发实践,定制化开发
在短视频行业迅猛发展的当下,企业和个人创作者为了扩大影响力、提升传播效果,纷纷采用短视频矩阵运营策略,同时管理多个平台、多个账号的内容发布。然而,频繁的文案创作需求让运营者疲于应对,如何高效产出高质量文案成…...

免费PDF转图片工具
免费PDF转图片工具 一款简单易用的PDF转图片工具,可以将PDF文件快速转换为高质量PNG图片。无需安装复杂的软件,也不需要在线上传文件,保护您的隐私。 工具截图 主要特点 🚀 快速转换:本地转换,无需等待上…...

【LeetCode】算法详解#6 ---除自身以外数组的乘积
1.题目介绍 给定一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O…...
git: early EOF
macOS报错: Initialized empty Git repository in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/.git/ remote: Enumerating objects: 2691797, done. remote: Counting objects: 100% (1760/1760), done. remote: Compressing objects: 100% (636/636…...
Fetch API 使用详解:Bearer Token 与 localStorage 实践
Fetch API:现代浏览器内置的用于发送 HTTP 请求的 API,Bearer Token:一种基于令牌的身份验证方案,常用于 JWT 认证,localStorage:浏览器提供的持久化存储方案,用于在客户端存储数据。 token是我…...