Nginx如何限流(nginx控制访问量)

Nginx如何限流(nginx控制访问量)

浏览次数:
信息来源: 用户投稿
更新日期: 2026-03-19
文章简介

文章主要介绍了nginx流量控制以及访问控制的实现,通过示例代码介绍,需要的朋友们下面随着小编来一起学习学习吧。 nginx流量控制 流量限制(rate-limiting),是Nginx中一个非常

2025阿里云双十一服务器活动

文章主要介绍了nginx流量控制以及访问控制的实现,通过示例代码介绍,需要的朋友们下面随着小编来一起学习学习吧。

nginx流量控制

流量限制(rate-limiting),是Nginx中一个非常实用,却经常被错误理解和错误配置的功能。我们可以用来限制用户在给定时间内HTTP请求的数量。请求,可以是一个简单网站首页的GET请求,也可以是登录表单的POST请求。流量限制可以用作安全目的,比如可以减慢暴力密码破解的速率。通过将传入请求的速率限制为真实用户的典型值,并标识目标URL地址(通过日志),还可以用来抵御DDOS攻击。更常见的情况,该功能被用来保护上游应用服务器不被同时太多用户请求所压垮。

以下将会介绍Nginx的流量限制的基础知识和高级配置,”流量限制”在NginxPlus中也适用。

1、Nginx如何限流

Nginx的”流量限制”使用漏桶算法(leakybucketalgorithm),该算法在通讯和分组交换计算机网络中广泛使用,用以处理带宽有限时的突发情况。就好比,一个桶口在倒水,桶底在漏水的水桶。如果桶口倒水的速率大于桶底的漏水速率,桶里面的水将会溢出;同样,在请求处理方面,水代表来自客户端的请求,水桶代表根据”先进先出调度算法”(FIFO)等待被处理的请求队列,桶底漏出的水代表离开缓冲区被服务器处理的请求,桶口溢出的水代表被丢弃和不被处理的请求。

2、配置基本的限流

“流量限制”配置两个主要的指令,和,如下所示:

指令定义了流量限制相关的参数,而指令在出现的上下文中启用流量限制(示例中,对于”/login/”的所有请求)。

指令通常在HTTP块中定义,使其可在多个上下文中使用,它需要以下三个参数:

  • Key&8211;定义用于存储每个IP地址状态以及被限制请求URL访问频率的共享内存区域。保存在内存共享区域的信息,意味着可以在Nginx的worker进程之间共享。定义分为两个部分:通过标识区域的名字,以及冒号后面跟区域大小。16000个IP地址的状态信息,大约需要1MB,所以示例中区域可以存储160000个IP地址。
  • Rate–定义最大请求速率。在示例中,速率不能超过每秒1个请求。Nginx实际上以毫秒的粒度来跟踪请求,所以速率限制相当于每1000毫秒1个请求。因为不允许”突发情况”(见下一章节),这意味着在前一个请求1000毫秒内到达的请求将被拒绝。
  • 指令设置流量限制和共享内存区域的参数,但实际上并不限制请求速率。所以需要通过添加

    指令,将流量限制应用在特定的或者块。在上面示例中,我们对请求进行流量限制。

    现在每个IP地址被限制为每秒只能请求1次,更准确地说,在前一个请求的1000毫秒内不能请求该URL。

    3、处理突发

    如果我们在1000毫秒内接收到2个请求,怎么办?对于第二个请求,Nginx将给客户端返回错误。这可能并不是我们想要的结果,因为应用本质上趋向于突发性。相反地,我们希望缓冲任何超额的请求,然后及时地处理它们。我们更新下配置,在中使用参数:

    参数定义了超出zone指定速率的情况下(示例中的区域,速率限制在每秒10个请求,或每100毫秒一个请求),客户端还能发起多少请求。上一个请求100毫秒内到达的请求将会被放入队列,我们将队列大小设置为20。

    这意味着,如果从一个给定IP地址发送21个请求,Nginx会立即将第一个请求发送到上游服务器群,然后将余下20个请求放在队列中。然后每100毫秒转发一个排队的请求,只有当传入请求使队列中排队的请求数超过20时,Nginx才会向客户端返回错误。

    4、配置流量控制相关功能

    默认情况下,Nginx会在日志中记录由于流量限制而延迟或丢弃的请求,如下所示:

    Nginx如何限流,nginx控制访问量

    默认情况下,Nginx以级别来记录被拒绝的请求,如上面示例中的所示(Nginx以较低级别记录延时请求,一般是级别)。如要更改Nginx的日志记录级别,需要使用指令。这里,我们将被拒绝请求的日志记录级别设置为:

    一定要定义日志位置和级别才可以:

    继续访问测试,看error.log日志

    2、发送到客户端的错误代码

    一般情况下,客户端超过配置的流量限制时,Nginx响应状态码为503(ServiceTemporarilyUnavailable)。可以使用指令来设置为其它状态码(例如下面的404状态码):

    、nginx流量控制总结

    以上已经涵盖了Nginx和NginxPlus提供的“流量限制”的很多功能,包括为HTTP请求的不同location设置请求速率,给“流量限制”配置参数。

    nginx访问控制

    1、nginx访问控制模块

    (1)基于IP的访问控制:http_access_module(2)基于用户的信任登录:http_auth_basic_module

    2、基于IP的访问控制

    虚拟机宿主机IP为,虚拟机IP为,故这里禁止宿主机访问,允许其他所有IP访问。宿主机访问,显示。当然也可以反向配置,同时也可以使用IP网段的配置方式,如,表示满足此网段的IP都可以访问。

    3、指定location拒绝所有请求

    如果你想拒绝某个指定URL地址的所有请求,而不是仅仅对其限速,只需要在块中配置all指令:

    3、基于用户的信任登录

    2、配置示例

    不为,开启登录验证功能,加载账号密码文件。

    3、建立口令文件

    4、访问测试

    5、局限性

    (1)用户信息依赖文件方式(2)操作管理机械,效率低下

    到此这篇关于nginx流量控制以及访问控制的实现的文章就介绍到这了,更多相关nginx流量控制及访问控制内容请搜索以前的文章或继续浏览下面的相关文章

    标签:
    网络托管公司有哪些(第三方托管公司)
    « 上一篇
    返回列表
    下一篇 »

    如本文对您有帮助,就请抽根烟吧!