1.用Nacos存储Sentinel的限流规则
1.创建工程,添加依赖
代码语言:javascript复制 <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
代码语言:javascript复制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.自定义埋点
代码语言:javascript复制@RestController
public class SentinelController {
@GetMapping("/hello")
//自定义埋点
@SentinelResource("hello")
public String hello(){
return "Hello Sentinel Demo";
}
}
4.添加Nacos配置
在Nacos中添加如图配置信息
配置内容:
代码语言:javascript复制[
{
"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