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后,再次请求后流控规则出现,实现了流控规则持久化,不用每次都配置!!

 

posted @   创客未来  阅读(541)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示