news 2026/2/12 7:08:44

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/2/7 0:14:39

Spring的反射与动态代理

1. Spring 反射与动态代理Spring 框架广泛使用反射和动态代理机制来增强灵活性与可扩展性&#xff0c;特别是在实现 AOP&#xff08;面向切面编程&#xff09;和动态 Bean 配置时。反射允许在运行时获取类的元数据并动态操作对象&#xff0c;而动态代理则允许在运行时创建代理对…

作者头像 李华
网站建设 2026/2/5 14:25:07

学霸同款9个AI论文平台,助你轻松搞定本科生毕业论文!

学霸同款9个AI论文平台&#xff0c;助你轻松搞定本科生毕业论文&#xff01; AI 工具助力论文写作&#xff0c;告别熬夜苦战 对于本科生而言&#xff0c;撰写毕业论文是一项既重要又棘手的任务。从选题到成稿&#xff0c;每一个环节都充满了挑战。而随着 AI 技术的不断发展&…

作者头像 李华
网站建设 2026/2/12 3:16:01

基于单片机的彩灯控制系统

收藏和点赞&#xff0c;您的关注是我创作的动力 文章目录 概要 一、研究的主要内容二、彩灯的方案设计3.1彩灯常见的工作模式3.2彩灯的设计方案以及工作原理3.2.1彩灯的设计方案3.2.2彩灯的工作原理3.4彩灯效果图 三、设计3.1 plc机型的选择3.2 程序框图 概要 随着社会经济和科…

作者头像 李华
网站建设 2026/2/10 10:43:10

基于python的智能健康检测系统设计与实现2025_v5gemqq6

前言基于Python的智能健康检测系统是一个集数据采集、分析、预警和可视化于一体的综合性健康管理平台。该系统利用Python强大的数据处理能力和丰富的机器学习库&#xff0c;结合可穿戴设备或医疗传感器&#xff0c;实现对用户健康状况的实时监测和智能分析&#xff0c;为用户提…

作者头像 李华
网站建设 2026/2/10 13:29:27

高效便捷JAVA汽车保养同城服务新选择

JAVA汽车保养同城服务通过跨平台协同、智能调度、数据安全保障及创新功能&#xff0c;为用户提供高效便捷的一键触达体验&#xff0c;成为同城汽车养护的新选择。 以下是具体分析&#xff1a; 一、技术架构&#xff1a;跨平台无缝衔接&#xff0c;支撑高并发场景 多端协同 Jav…

作者头像 李华