Sentinel 规则持久化
1.产生原因
一旦我们重启应用,sentinel规则将消失,生产环境需要将配置规则进行持久化
2.持久化思想
以8401为例。
将限流配置规则持久化进Nacos保存,只要刷新8401某个rest地址,sentinel控制台的流量规则就能看到,只要Nacos里面的配置不删除,针对8401上sentinel上的流控规则持续有效。
3.实现步骤
3.1 改POM
在POM中增加Sentinel持久化的引入
<!--SpringCloud alibaba sentinel-datasource-nacos 后续做持久化用到--> <dependency> <groupId>com.alibaba.csp</groupId> <artifactId>sentinel-datasource-nacos</artifactId> </dependency>
3.2 改YML
server:
port: 8401
spring:
application:
name: cloudalibaba-sentinel-service
cloud:
nacos:
discovery:
#Nacos服务注册中心地址
server-addr: localhost:8848
sentinel:
transport:
#配置Sentinel dashboard地址
dashboard: localhost:8080
#默认8719端口,假如被占用会自动8719开始依次+1扫描,直至找到未被占用的端口
port: 8719
datasource:
ds1:
nacos:
server-addr: localhost:8848
dataId: cloudalibaba-sentinel-service
groupId: DEFAULT_GROUP
data-type: json
rule-type: flow
management:
endpoints:
web:
exposure:
include: '*'
3.3 在Nacos中配置规则
json:
[ { "resource":"/rateLimit/byUrl", "limitApp":"default", "grade":1, "count":1, "strategy":0, "controlBehavior":0, "clusterMode":false } ]
参数说明:
resource:资源名称;
limitApp:来源应用;
grade:阈值类型,0表示线程数,1表示QPS;
count:单机阈值;
strategy:流控模式,0表示直接,1表示关联,2表示链路;
controlBehavior:流控效果,0表示快速失败,1表示Warm Up,2表示排队等待;
clusterMode:是否集群;
java中controller方法
//======Nacos datasource Sentinel======
@GetMapping("/rateLimit/byUrl")
public String byUrl(){
return "------/rateLimit/byUrl";
}
请求一次在Sentinel中可以查看流控规则
快速请求是触发流控限制
停掉8401服务后,Sentinel中流控规则消失
重启8401后,再次请求后流控规则出现,实现了流控规则持久化,不用每次都配置!!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!