news 2026/4/16 11:59:54

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/12 8:37:04

【Java基础|Java +Socket +Swing聊天室】

Java Socket 聊天室 - 零基础手把手教程 GitHub地址&#xff1a;https://github.com/RONGX563647/NewChatRoom 本教程面向零基础学习者&#xff0c;从最基础的概念开始&#xff0c;一步步带你完成一个完整的聊天室项目。 目录 准备工作基础知识第一阶段&#xff1a;创建项目第…

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

Spring的自定义注解与处理器

1. 自定义注解的定义 自定义注解是 Java 中的一种元数据标记&#xff0c;允许在代码中添加自定义信息&#xff0c;并能通过反射机制进行处理。我们首先定义一个自定义注解&#xff0c;然后在 Spring 中使用该注解来标识需要处理的类或方法。 示例&#xff1a;定义一个简单的自…

作者头像 李华
网站建设 2026/4/12 1:36:47

基于单片机的养殖场温度控制系统设计

博主主页&#xff1a;单片机辅导设计 博主简介&#xff1a;专注单片机技术领域和毕业设计项目。 主要内容&#xff1a;毕业设计、简历模板、学习资料、技术咨询。 文章目录主要介绍一、控制系统设计二、系统方案设计2.1 系统运行方案设计2.1.1 羊舍环境温度的确定三、 系统仿真…

作者头像 李华
网站建设 2026/4/16 6:26:57

AI 软件开发的管理

管理 AI 软件开发不仅是技术的堆叠&#xff0c;更是对不确定性、数据资产以及人机协作模式的深度治理。与传统软件工程相比&#xff0c;AI 项目管理的核心挑战在于&#xff1a;代码逻辑是确定的&#xff0c;但模型的输出是概率性的。以下是管理 AI 软件开发的关键维度&#xff…

作者头像 李华
网站建设 2026/4/15 3:45:49

Adobe Premiere Pro 26.0 - 原生支持Windows on ARM

一句话亮点&#xff1a;Adobe首次为ARM平台提供原生支持&#xff0c;适配高通Snapdragon X系列处理器设备。详细描述&#xff1a;Adobe发布26.0版本&#xff0c;标志着其创意软件生态系统正式进入ARM时代。Premiere Pro、After Effects、Audition及Media Encoder首次实现对Wind…

作者头像 李华