前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >用Nacos存储Sentinel的限流规则

用Nacos存储Sentinel的限流规则

作者头像
星哥玩云
发布2022-09-15 14:37:00
5330
发布2022-09-15 14:37:00
举报
文章被收录于专栏:开源部署开源部署

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中添加如图配置信息

image20200725204644276.png
image20200725204644276.png

配置内容:

代码语言: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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.用Nacos存储Sentinel的限流规则
    • 1.创建工程,添加依赖
      • 2.添加客户端配置
        • 3.自定义埋点
          • 4.添加Nacos配置
            • 5.测试配置的持久化
            相关产品与服务
            对象存储
            对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档