跳转到内容
OpenClaw 不踩坑恶意 Skills ,企业需 Skills Registry:Nacos 3.2 发布点此了解

流量防护

流量防护插件

流量防护插件用于在高压或异常访问场景下保护 Nacos 服务端。它可以限制连接数量,也可以限制核心接口的 TPS,帮助服务端快速拒绝过量请求,避免局部流量问题扩大成集群不可用。

Nacos 2.3.0 起支持通过 SPI 注入流量防护插件。当前默认实现的插件名是 nacos。如果没有配置 nacos.plugin.control.manager.type,Nacos 会使用 no limit 实现,不主动限制连接和 TPS。

核心概念

概念说明
ControlPoint被保护的访问点。例如节点总连接数、配置查询、配置发布、服务注册等。
ConnectionControlRule连接数规则,用于限制单个节点可接受的连接数量。
TpsControlRuleTPS 规则,用于限制某个 ControlPoint 的请求频率。
monitor 模式只统计和记录命中情况,不拦截请求。适合灰度观察。
intercept 模式命中规则后直接拒绝请求。适合确认阈值后的保护动作。

启用默认实现

${nacos.home}/conf/application.properties 中配置:

nacos.plugin.control.manager.type=nacos

默认规则文件存储在 ${nacos.home}/data/connection${nacos.home}/data/tps。如果希望换到其他目录:

nacos.plugin.control.rule.local.basedir=/opt/nacos-control-rules

此时规则会存储在:

/opt/nacos-control-rules/data/connection
/opt/nacos-control-rules/data/tps

启动后可以查看 ${nacos.home}/logs/plugin-control.log,确认插件是否加载成功。

配置连接数规则

连接数规则文件名固定为 limitRule

Terminal window
mkdir -p ${nacos.home}/data/connection
cat > ${nacos.home}/data/connection/limitRule <<'EOF'
{"countLimit":1000}
EOF

规则字段:

字段类型说明
countLimitint节点总连接数限制。-1 表示不限制。
monitorIpListSet<String>需要详细观察的 IP 列表。命中后会在 remote-digest.log 中记录更多连接行为。

配置 TPS 规则

每个 ControlPoint 对应一个规则文件,文件名建议与 ControlPoint 一致:

Terminal window
mkdir -p ${nacos.home}/data/tps
cat > ${nacos.home}/data/tps/ConfigQuery <<'EOF'
{"pointName":"ConfigQuery","pointRule":{"maxCount":100,"monitorType":"intercept"}}
EOF

规则字段:

字段类型说明
pointNameString规则对应的 ControlPoint 名称。
pointRule.ruleNameString规则名。同一个 ControlPoint 可以有多个规则名。
pointRule.maxCountintTPS 上限。-1 表示不限制。
pointRule.periodTimeUnit统计周期,默认是秒级。
pointRule.monitorTypeStringmonitorintercept

生产环境建议先使用 monitor 模式观察真实流量,再切换到 intercept 模式。

支持的 ControlPoint

ControlPoint保护内容请求来源
connection节点总连接数gRPC 长连接、配置长轮询
HealthCheckgRPC 健康检查gRPC
ConfigPublish配置发布HTTP、gRPC
ConfigQuery配置查询HTTP、gRPC
ConfigRemove配置删除gRPC
ConfigListen配置监听gRPC
ConfigFuzzyWatch配置模糊订阅gRPC
ClusterConfigChangeNotify集群配置变更通知gRPC
RemoteNamingInstanceRegisterDeregister服务实例注册和注销gRPC
RemoteNamingInstanceBatchRegister服务实例批量注册gRPC
RemoteNamingServiceListQuery服务列表查询gRPC
RemoteNamingServiceQuery服务查询gRPC
RemoteNamingServiceSubscribeUnSubscribe服务订阅和取消订阅gRPC
NamingInstanceRegister服务实例注册HTTP
NamingInstanceDeregister服务实例注销HTTP
NamingInstanceUpdate服务实例更新HTTP
NamingInstanceMetadataUpdate服务实例元数据更新HTTP
NamingServiceSubscribe服务订阅和查询HTTP
NamingInstanceQuery单个服务实例查询HTTP
NamingServiceRegister服务创建HTTP
NamingServiceDeregister服务删除HTTP
NamingServiceQuery服务查询HTTP
NamingServiceListQuery服务列表查询HTTP
NamingServiceUpdate服务元数据更新HTTP

ControlPoint 名称来自代码中的 @TpsControl 注解。不同 Nacos 版本可能会新增 ControlPoint,升级后建议重新核对目标版本代码和默认文档。

外部规则存储

默认实现使用本地文件保存规则。集群规模较大、节点较多或容器化部署时,逐个节点维护本地规则会比较困难。此时可以实现外部规则存储插件:

com.alibaba.nacos.plugin.control.spi.ExternalRuleStorageBuilder

并在配置中指定外部存储类型:

nacos.plugin.control.rule.external.storage=${controlPluginName}

外部存储可以对接数据库、配置中心或企业内部规则系统。具体一致性和下发策略由插件实现负责。

自定义插件开发

自定义流量防护插件需要实现:

SPI / 抽象类作用
ControlManagerBuilder声明插件名,并创建连接数管理器和 TPS 管理器。
ConnectionControlManager加载连接数规则,并判断新连接是否允许建立。
TpsControlManager注册 ControlPoint,加载 TPS 规则,并判断请求是否允许继续执行。
ExternalRuleStorageBuilder可选。用于接入外部规则存储。

核心依赖:

<dependency>
<groupId>com.alibaba.nacos</groupId>
<artifactId>nacos-control-plugin</artifactId>
<version>${project.version}</version>
</dependency>

实现后通过 SPI 文件注册:

META-INF/services/com.alibaba.nacos.plugin.control.spi.ControlManagerBuilder

如果实现了外部规则存储,还需要注册:

META-INF/services/com.alibaba.nacos.plugin.control.spi.ExternalRuleStorageBuilder

运维建议

  • 先观察再拦截。新规则先用 monitor 模式运行一段时间,确认阈值不会误伤正常流量。
  • 规则按节点生效。本地文件规则不会自动同步到其他节点。
  • 对核心接口设置不同阈值。配置查询、配置发布、服务注册、服务订阅的流量特征不同,不建议共用一个阈值。
  • 保留应急入口。过低的连接数或 TPS 阈值可能影响控制台、SDK、探活和运维接口。
  • 结合监控使用。流量防护适合做保护动作,容量评估仍应结合连接数、请求量、线程池、数据库和 JVM 监控。