如何利用 limit_req_zone 和请求 URI 配合,对特定负载均衡接口进行精准防护?

2026-05-07 08:370阅读0评论SEO教程
  • 内容介绍
  • 相关推荐

本文共计788个文字,预计阅读时间需要4分钟。

如何利用 limit_req_zone 和请求 URI 配合,对特定负载均衡接口进行精准防护?

直接使用`limit_req_zone结合`$uri`变量,就能对特定接口进行精确的流量限制,这是保障负载均衡后端核心路径(如登录、下单、搜索等)最常用且最有效的方法。

为什么选 $uri 而不是只用 IP?

单靠 IP 限流容易误伤——同一出口(如企业 NAT、校园网)下多个用户共用一个 IP,限制过严会影响正常访问;而只按 IP 放宽,又挡不住单个用户高频刷某个接口。用 $uri 可以把防护粒度落到具体路径上,让“/login”、“/api/order”这些敏感接口单独受控,其他静态资源或首页则不受影响。

基础配置写法(必须放在 http 块)

nginx.confhttp { } 区域中添加:

limit_req_zone $uri zone=byuri:10m rate=5r/s;

说明:
$uri 是标准化后的请求路径(不含参数和查询字符串),例如 /api/v1/login
zone=byuri:10m 表示分配 10MB 共享内存,约可存储 16 万个不同 URI 的计数状态;
rate=5r/s 意味着每个唯一 URI 每秒最多处理 5 个请求。

阅读全文

本文共计788个文字,预计阅读时间需要4分钟。

如何利用 limit_req_zone 和请求 URI 配合,对特定负载均衡接口进行精准防护?

直接使用`limit_req_zone结合`$uri`变量,就能对特定接口进行精确的流量限制,这是保障负载均衡后端核心路径(如登录、下单、搜索等)最常用且最有效的方法。

为什么选 $uri 而不是只用 IP?

单靠 IP 限流容易误伤——同一出口(如企业 NAT、校园网)下多个用户共用一个 IP,限制过严会影响正常访问;而只按 IP 放宽,又挡不住单个用户高频刷某个接口。用 $uri 可以把防护粒度落到具体路径上,让“/login”、“/api/order”这些敏感接口单独受控,其他静态资源或首页则不受影响。

基础配置写法(必须放在 http 块)

nginx.confhttp { } 区域中添加:

limit_req_zone $uri zone=byuri:10m rate=5r/s;

说明:
$uri 是标准化后的请求路径(不含参数和查询字符串),例如 /api/v1/login
zone=byuri:10m 表示分配 10MB 共享内存,约可存储 16 万个不同 URI 的计数状态;
rate=5r/s 意味着每个唯一 URI 每秒最多处理 5 个请求。

阅读全文