用Nacos存储Sentinel的限流规则

2022-09-15 14:37:00 浏览数 (1)

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

0 人点赞