【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 主要功能特点…...
Vue记事本应用实现教程
文章目录 1. 项目介绍2. 开发环境准备3. 设计应用界面4. 创建Vue实例和数据模型5. 实现记事本功能5.1 添加新记事项5.2 删除记事项5.3 清空所有记事 6. 添加样式7. 功能扩展:显示创建时间8. 功能扩展:记事项搜索9. 完整代码10. Vue知识点解析10.1 数据绑…...

地震勘探——干扰波识别、井中地震时距曲线特点
目录 干扰波识别反射波地震勘探的干扰波 井中地震时距曲线特点 干扰波识别 有效波:可以用来解决所提出的地质任务的波;干扰波:所有妨碍辨认、追踪有效波的其他波。 地震勘探中,有效波和干扰波是相对的。例如,在反射波…...
云计算——弹性云计算器(ECS)
弹性云服务器:ECS 概述 云计算重构了ICT系统,云计算平台厂商推出使得厂家能够主要关注应用管理而非平台管理的云平台,包含如下主要概念。 ECS(Elastic Cloud Server):即弹性云服务器,是云计算…...

练习(含atoi的模拟实现,自定义类型等练习)
一、结构体大小的计算及位段 (结构体大小计算及位段 详解请看:自定义类型:结构体进阶-CSDN博客) 1.在32位系统环境,编译选项为4字节对齐,那么sizeof(A)和sizeof(B)是多少? #pragma pack(4)st…...

华为OD机试-食堂供餐-二分法
import java.util.Arrays; import java.util.Scanner;public class DemoTest3 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseint a in.nextIn…...
Java多线程实现之Thread类深度解析
Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

【分享】推荐一些办公小工具
1、PDF 在线转换 https://smallpdf.com/cn/pdf-tools 推荐理由:大部分的转换软件需要收费,要么功能不齐全,而开会员又用不了几次浪费钱,借用别人的又不安全。 这个网站它不需要登录或下载安装。而且提供的免费功能就能满足日常…...
JavaScript基础-API 和 Web API
在学习JavaScript的过程中,理解API(应用程序接口)和Web API的概念及其应用是非常重要的。这些工具极大地扩展了JavaScript的功能,使得开发者能够创建出功能丰富、交互性强的Web应用程序。本文将深入探讨JavaScript中的API与Web AP…...

并发编程 - go版
1.并发编程基础概念 进程和线程 A. 进程是程序在操作系统中的一次执行过程,系统进行资源分配和调度的一个独立单位。B. 线程是进程的一个执行实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位。C.一个进程可以创建和撤销多个线程;同一个进程中…...