news 2026/4/18 10:44:02

Sentinel 实现流控规则的Nacos推送和拉取

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Sentinel 实现流控规则的Nacos推送和拉取

Sentinel 控制台(集群流控管理)

规则配置

要通过 Sentinel 控制台配置集群流控规则,需要对控制台进行改造。我们提供了相应的接口进行适配。

从 Sentinel 1.4.0 开始,我们抽取出了接口用于向远程配置中心推送规则以及拉取规则:

  • DynamicRuleProvider<T>: 拉取规则
  • DynamicRulePublisher<T>: 推送规则

对于集群限流的场景,由于每个集群限流规则都需要唯一的 flowId,因此我们建议所有的规则配置都通过动态规则源进行管理,并在统一的地方生成集群限流规则。

我们提供了新版的流控规则页面,可以针对应用维度推送规则,对于集群限流规则可以自动生成 flowId。用户只需实现DynamicRuleProviderDynamicRulePublisher接口,即可实现应用维度推送(URL:/v2/flow)。

注:应用维度推送流控规则页面的默认实现仅仅是对旧版 API 的兼容(批量推送有效的机器/拉取最近有效的机器的规则),对集群规则无效。生产环境下不推荐使用默认实现,建议对接动态规则源。

我们提供了 Nacos、ZooKeeper 和 Apollo 的推送和拉取规则实现示例(位于test目录下)。以 Nacos 为例,若希望使用 Nacos 作为动态规则配置中心,用户可以提取出相关的类,然后只需在FlowControllerV2中指定对应的 bean 即可开启 Nacos 适配。前端页面需要手动切换,或者修改前端路由配置(sidebar.html流控规则路由从dashboard.flowV1改成dashboard.flow即可,注意簇点链路页面对话框需要自行改造)。

@Autowired@Qualifier("flowRuleNacosProvider")privateDynamicRuleProvider<List<FlowRuleEntity>>ruleProvider;@Autowired@Qualifier("flowRuleNacosPublisher")privateDynamicRulePublisher<List<FlowRuleEntity>>rulePublisher;

默认 Nacos 适配的 dataId 和 groupId 约定如下:

  • groupId:SENTINEL_GROUP
  • 流控规则 dataId:{appName}-flow-rules,比如应用名为 appA,则 dataId 为appA-flow-rules

用户可以在NacosConfigUtil修改对应的 groupId 和 dataId postfix。用户可以在NacosConfig配置对应的Converter,默认已提供FlowRuleEntity的 decoder 和 encoder。

注意:接入端也需要注册对应的动态规则源,参考 集群流控规则配置文档。

集群流控管理

注:客户端必须引入集群限流相关依赖(比如需要使用集群限流,则需要引入集群限流 client 依赖;若需要作为嵌入式的集群限流服务端,则还需要引入集群限流 server 依赖),否则无法进行配置。

Sentinel 1.4.1 版本的控制台引入了应用维度的集群流控管理页面,可以方便地从应用维度分配 token server、查看相关状态。我们可以在侧边栏点击“集群流控”,进入 Token Server 列表页面,可以查看当前应用下所有的 token server 列表及相关状态:

我们可以点击右上角的“添加 Token Server”按钮来添加新的 token server 并分配 client:

Token Client 列表


  • Sentinel 官方网站
  • OpenSergo 微服务治理
  • 文档
    • Read Me
    • 新手指南
    • Sentinel 介绍
    • FAQ
    • Roadmap
    • 如何使用
    • 工作原理
    • 流量控制
    • 集群流控(分布式流控)
    • 网关流控
    • 熔断降级
    • 热点参数限流
    • 系统自适应限流
    • 黑白名单控制
    • 实时监控数据
    • 动态规则
    • 控制台
    • 生产环境使用 Sentinel
    • 阿里云企业版 Sentinel
    • OpenSergo 控制面
    • 启动配置项
    • 注解埋点支持
    • 主流框架适配
    • Envoy 集群流量控制
    • 多语言生态
    • 开源贡献指南
  • 阿里云 微服务解决方案
  • Release Notes
  • Related Blog
  • Awesome Sentinel
  • Documents
    • Read Me
    • Introduction
    • How to Use
    • How it Works
    • Flow Control
    • Parameter Flow Control
    • Cluster Flow Control
    • API Gateway Flow Control
    • Circuit Breaking
    • Adaptive System Protection
    • Metrics
    • General Configuration
    • Dynamic Rule Configuration
    • Dashboard
    • Integrations with open-source frameworks
    • Contribution Guideline

https://github.com/alibaba/Sentinel/wiki/Sentinel-%E6%8E%A7%E5%88%B6%E5%8F%B0%EF%BC%88%E9%9B%86%E7%BE%A4%E6%B5%81%E6%8E%A7%E7%AE%A1%E7%90%86%EF%BC%89#%E8%A7%84%E5%88%99%E9%85%8D%E7%BD%AE

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 19:41:33

13 秒插入 30 万条数据,这才是批量插入正确的姿势!

01 30万条数据插入数据库验证 验证的数据库表结构如下&#xff1a; CREATETABLEt_user ( idint(11) NOTNULL AUTO_INCREMENT COMMENT用户id, usernamevarchar(64) DEFAULTNULLCOMMENT用户名称, ageint(4) DEFAULTNULLCOMMENT年龄,PRIMARY KEY (id) ) ENGINEInnoDBDEFAULTCHAR…

作者头像 李华
网站建设 2026/4/18 7:24:04

RAG 深度实践系列(六):基于科大讯飞 RAG + 星火知识库的企业级实战指南

目录一、 企业级 RAG 的落地挑战与科大讯飞的生态赋能1.1、 讯飞开放平台&#xff1a;RAG 的“大脑”与“算力”底座1.2、 星火知识库&#xff1a;私域知识向量化的工程实现二、 工程实践2.1、 应用创建与密钥管理2.2、 接口鉴权认证的底层逻辑与时间戳偏移处理2.3、 文档管理流…

作者头像 李华
网站建设 2026/4/16 16:58:36

计算机毕业设计之基于springboot的学测评系统设计与实现

随着网络科技的不断发展以及人们经济水平的逐步提高&#xff0c;网络技术如今已成为人们生活中不可缺少的一部分&#xff0c;而信息管理系统是通过计算机技术&#xff0c;针对用户需求开发与设计&#xff0c;该技术尤其在各行业领域发挥了巨大的作用&#xff0c;有效地促进了学…

作者头像 李华
网站建设 2026/4/18 7:02:50

基于单片机的酒精监测系统

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 概要 一、总方案设计2.1 分析2.2 酒精浓度监测系统方案 二、硬件设计报警电路 三、系统电路设计4.2 主程序框图 四、 总结 概要 近年来&#xff0c;车祸惨案频频发…

作者头像 李华
网站建设 2026/4/18 5:31:15

NLIS01控制器模块

NLIS01 控制器模块简介NLIS01 控制器模块用于工业控制系统中&#xff0c;负责执行控制逻辑、处理现场数据&#xff0c;并协调各功能模块的运行。作为系统核心控制单元&#xff0c;负责逻辑运算与控制决策支持多种控制策略&#xff0c;满足不同工艺需求数据处理速度快&#xff0…

作者头像 李华