组团学

用Nacos存储Sentinel的限流规则

阅读 (9844708)

1.用Nacos存储Sentinel的限流规则

1.创建工程,添加依赖

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId> </dependency> <dependency> <groupId>com.alibaba.csp</groupId> <artifactId>sentinel-datasource-nacos</artifactId> </dependency>

2.添加客户端配置

添加Sentinel的控制地址、Nacos的地址,并自定义Nacos中的dataId和groupId

spring.application.name=datasource-nacos
# 应用服务 WEB 访问端口
server.port=8092
spring.cloud.sentinel.transport.dashboard=localhost:8080
#Nacos地址
spring.cloud.sentinel.datasource.ds.nacos.server-addr=localhost:8848
#自定义Nacos中存储规则的dataId
spring.cloud.sentinel.datasource.ds.nacos.data-id=${spring.application.name}
#自定义Nacos中存储规则的groupid
spring.cloud.sentinel.datasource.ds.nacos.group-id=DEFAULT_GROUP
#定义存储的规则类型为flow
spring.cloud.sentinel.datasource.ds.nacos.rule-type=flow

3.自定义埋点

@RestController public class SentinelController { @GetMapping("/hello") //自定义埋点 @SentinelResource("hello") public String hello(){ return "Hello Sentinel Demo"; } }

4.添加Nacos配置

在Nacos中添加如图配置信息

image20200725204644276.png

配置内容:

[ { "resource": "/hello", "limitApp": "default", "grade": 1, "count": 3, "strategy": 0, "controlBehavior": 0, "clusterMode": false } ]
  • resource:资源名,即限流规则的作用对象

  • limitApp: 流控针对的调用来源

  • grade : 限流阀值类型 (QPS或并发线程数).0代表根据并发数量来限流,1代表根据QPS来进行流量控制

  • count: 限流阀值

  • strategy: 调用关系限流策略

  • controlBehavior:流量控制效果,有3个选项:直接拒绝、Warm Up、匀速排队

  • clusterMode:是否为集群模式

5.测试配置的持久化

步骤

1.确保启动了Nacos、Sentinel和自己编写的客户端

2.访问 http://localhost:8088/hello,并多次高频刷新.如果出现"Blocked by Sentinel (flow limiting)"的信息,则代表配置成功

3.来到Sentinel流控规则界面,可以看到在Nacos中配置的限流规则

4.在Senitnel中修改限流规则,比如修改单机阀值为10

5.重启客户端,会发现Sentinel中的限流阀值被刷新为3,代表修改并未持久化

6.在Nacos中修改count的值为20,然后访问http://localhost:8088/hello

7.进入Sentine流控规则界面,可以看到阀值变成了20

需要 登录 才可以提问哦