【Nginx-5】Nginx 限流配置指南:保护你的服务器免受流量洪峰冲击

在现代互联网应用中,流量波动是常态。无论是突发的用户访问高峰,还是恶意攻击,都可能导致服务器资源耗尽,进而影响服务的可用性。为了应对这种情况,限流(Rate Limiting)成为了一种常见的保护措施。Nginx 作为一款高性能的 Web 服务器和反向代理服务器,提供了强大的限流功能,可以帮助我们有效控制流量,保护后端服务。

1. 为什么需要限流?

在讨论如何配置限流之前,我们先来了解一下为什么需要限流。

  1. 防止服务器过载:当流量突然激增时,服务器可能会因为处理不过来而崩溃。限流可以限制单位时间内的请求数量,避免服务器过载。
  2. 防止恶意攻击:某些恶意用户或攻击者可能会通过大量的请求来消耗服务器资源,导致正常用户无法访问。限流可以有效抵御这种攻击。
  3. 保障服务质量:通过限流,可以确保核心业务在流量高峰期仍然能够正常运行,避免因为流量激增而导致服务质量下降。

2. Nginx 限流的基本概念

Nginx 提供了两种主要的限流方式:

  1. 基于请求速率的限流(Rate Limiting):限制单位时间内的请求数量。
  2. 基于连接数的限流(Connection Limiting):限制同时处理的连接数。

3. 基于请求速率的限流配置

3.1 limit_req_zone 指令

limit_req_zone 是 Nginx 中用于定义请求速率限流策略的指令。它定义了一个共享内存区域,用于存储请求速率的统计信息。

limit_req_zone $binary_remote_addr zone=rate_limit_zone:10m rate=10r/s;
  • $binary_remote_addr:表示使用客户端的 IP 地址作为限流的键。你也可以使用其他变量,如 $http_x_forwarded_for 或自定义变量。
  • zone=rate_limit_zone:10m:定义了一个名为 rate_limit_zone 的共享内存区域,大小为 10MB。这个区域用于存储限流的状态信息。
  • rate=10r/s:表示每秒最多允许 10 个请求。你也可以使用 r/m 表示每分钟最多允许的请求数。

3.2 limit_req 指令

limit_req 指令用于在具体的 locationserver 块中应用请求速率限流策略。

server {
    location /api/ {
        limit_req zone=rate_limit_zone burst=5 nodelay;
        proxy_pass http://backend_server;
    }
}
  • zone=rate_limit_zone:指定使用之前定义的 rate_limit_zone 限流区域。
  • burst=5:表示允许突发请求的数量。如果请求速率超过了限流速率,Nginx 会将这些请求放入一个队列中,burst 参数定义了这个队列的大小。
  • nodelay:表示不延迟处理突发请求。如果没有这个参数,Nginx 会按照限流速率逐个处理请求,可能会导致响应时间增加。

3.3 请求速率限流的工作原理

当 Nginx 接收到请求时,它会根据 limit_req_zone 中定义的键(如客户端 IP 地址)来判断请求是否超过了限流速率。如果超过了限流速率,Nginx 会根据 burst 参数决定是否将请求放入队列中。如果队列已满,Nginx 会返回 503 错误(Service Temporarily Unavailable)。

4. 基于连接数的限流配置

4.1 limit_conn_zone 指令

limit_conn_zone 是 Nginx 中用于定义连接数限流策略的指令。它定义了一个共享内存区域,用于存储连接数的统计信息。

limit_conn_zone $binary_remote_addr zone=conn_limit_zone:10m;
  • $binary_remote_addr:表示使用客户端的 IP 地址作为限流的键。你也可以使用其他变量,如 $http_x_forwarded_for 或自定义变量。
  • zone=conn_limit_zone:10m:定义了一个名为 conn_limit_zone 的共享内存区域,大小为 10MB。这个区域用于存储连接数的状态信息。

4.2 limit_conn 指令

limit_conn 指令用于在具体的 locationserver 块中应用连接数限流策略。

server {
    location /api/ {
        limit_conn conn_limit_zone 10;
        proxy_pass http://backend_server;
    }
}
  • limit_conn conn_limit_zone 10:表示每个客户端 IP 地址最多允许同时建立 10 个连接。

4.3 连接数限流的工作原理

当 Nginx 接收到连接请求时,它会根据 limit_conn_zone 中定义的键(如客户端 IP 地址)来判断当前连接数是否超过了限制。如果超过了限制,Nginx 会拒绝新的连接请求,并返回 503 错误(Service Temporarily Unavailable)。

5. 配置示例

下面是一个完整的 Nginx 限流配置示例,结合了基于请求速率的限流和基于连接数的限流。

http {
    # 定义请求速率限流区域
    limit_req_zone $binary_remote_addr zone=rate_limit_zone:10m rate=10r/s;

    # 定义连接数限流区域
    limit_conn_zone $binary_remote_addr zone=conn_limit_zone:10m;

    server {
        listen 80;
        server_name example.com;

        location /api/ {
            # 应用请求速率限流策略
            limit_req zone=rate_limit_zone burst=20 nodelay;

            # 应用连接数限流策略
            limit_conn conn_limit_zone 10;

            proxy_pass http://backend_server;
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }
    }
}

解释:

  • limit_req_zone $binary_remote_addr zone=rate_limit_zone:10m rate=10r/s;:定义了一个名为 rate_limit_zone 的请求速率限流区域,每秒最多允许 10 个请求。
  • limit_conn_zone $binary_remote_addr zone=conn_limit_zone:10m;:定义了一个名为 conn_limit_zone 的连接数限流区域。
  • limit_req zone=rate_limit_zone burst=20 nodelay;:在 /api/ 路径下应用请求速率限流策略,允许突发请求最多 20 个,并且不延迟处理这些请求。
  • limit_conn conn_limit_zone 10;:在 /api/ 路径下应用连接数限流策略,每个客户端 IP 地址最多允许同时建立 10 个连接。

6. 限流的常见问题与优化

6.1 如何处理不同用户的限流需求?

如果你的应用需要对不同用户进行不同的限流策略,可以使用自定义变量来替代 $binary_remote_addr。例如,如果你使用 JWT 进行身份验证,可以在 Nginx 中解析 JWT 并提取用户 ID,然后使用用户 ID 作为限流的键。

limit_req_zone $jwt_user_id zone=user_rate_limit:10m rate=5r/s;
limit_conn_zone $jwt_user_id zone=user_conn_limit:10m;

6.2 如何处理代理后的客户端 IP?

如果你的 Nginx 服务器位于代理服务器之后(如 CDN 或负载均衡器),你可能需要使用 $http_x_forwarded_for$proxy_add_x_forwarded_for 来获取真实的客户端 IP 地址。

limit_req_zone $http_x_forwarded_for zone=proxy_rate_limit:10m rate=10r/s;
limit_conn_zone $http_x_forwarded_for zone=proxy_conn_limit:10m;

6.3 如何处理限流误伤?

有时候,限流可能会误伤正常用户。为了避免这种情况,你可以:

  • 增加 burst:允许更多的突发请求。
  • 使用 nodelay 参数:避免请求被延迟处理,减少用户体验的影响。
  • 动态调整限流策略:根据服务器的负载情况动态调整限流速率。

7. 总结

Nginx 的限流功能是保护服务器免受流量洪峰和连接风暴冲击的重要工具。通过合理配置 limit_req_zonelimit_req 指令,你可以有效地控制请求速率;通过配置 limit_conn_zonelimit_conn 指令,你可以限制同时处理的连接数。

在实际应用中,限流策略需要根据具体的业务需求进行调整。你可以通过增加 burst 值、使用自定义变量、处理代理后的客户端 IP 等方式来优化限流配置,确保限流策略既能保护服务器,又不会误伤正常用户。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/940586.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

WebRTC搭建与应用(一)-ICE服务搭建

WebRTC搭建与应用(一) 近期由于项目需要在研究前端WebGL渲染转为云渲染,借此机会对WebRTC、ICE信令协议等有了初步了解,在此记录一下,以防遗忘。 第一章 ICE服务搭建 文章目录 WebRTC搭建与应用(一)前言一、ICE是什么?二、什么…

LabVIEW伸缩臂参数监控系统

LabVIEW开发伸缩臂越野叉车参数监控系统主要应用于工程机械中的越野叉车,以提高车辆的作业效率和故障诊断能力。系统通过PEAK CAN硬件接口和LabVIEW软件平台实现对叉车作业参数的实时监控和故障分析,具有良好的实用性和推广价值。 系统组成 系统主要由P…

VR博物馆能模拟哪些历史场景?

VR博物馆以其卓越的模拟能力,能够带领观众穿越时空,体验从古罗马的斗兽场到中世纪的欧洲城堡,从文艺复兴的佛罗伦萨到工业革命的蒸汽机,再到二战的紧张战场,每一种历史场景都栩栩如生,让人仿佛亲历其境&…

网络安全防范

实践内容 学习总结 PDR,$$P^2$$DR安全模型。 防火墙(Firewall): 网络访问控制机制,布置在网际间通信的唯一通道上。 不足:无法防护内部威胁,无法阻止非网络传播形式的病毒,安全策略…

投标心态:如何在“标海战术”中保持清醒的头脑?

在竞争激烈的市场环境下,“标海战术”——即大规模参与投标——已经成为许多企业争取市场份额的重要策略。然而,盲目追求投标数量可能导致资源浪费、团队疲劳以及战略目标的模糊化。在这种高强度的竞争模式中,如何保持清醒的头脑,…

ICLR 2025 | 时间序列(Time Series)高分论文总结

ICLR2025已经结束了讨论阶段,进入了meta-review阶段,分数应该不会有太大的变化了,本文总结了其中时间序列(Time Series)高分的论文。如有疏漏,欢迎大家补充。 挑选原则:均分要大于等于6(≥6,即…

SpringBoot集成ENC对配置文件进行加密

在线MD5生成工具 配置文件加密&#xff0c;集成ENC 引入POM依赖 <!-- ENC配置文件加密 --><dependency><groupId>com.github.ulisesbocchio</groupId><artifactId>jasypt-spring-boot-starter</artifactId><version>2.1.2</ver…

ASP.NET|日常开发中数据集合详解

ASP.NET&#xff5c;日常开发中数据集合详解 前言一、数组&#xff08;Array&#xff09;1.1 定义和基本概念1.2 数组的操作 二、列表&#xff08;List<T>&#xff09;2.1 特点和优势2.2 常用操作 三、字典&#xff08;Dictionary<K, V>&#xff09;3.1 概念和用途…

金融信息系统多活技术-应用策略

目录 概述 ​编辑 多活应用场景 流水型系统 账户型系统 流水型系统应用策略 业务模型说明 系统并行策略 接入和路由策略 系列阅读 概述 本文件提出了金融信息系统多活技术的应用指南&#xff0c;金融机构可根据自身业务需要&#xff0c;结合本文件进行 多活信息系统的…

大数据之Hbase环境安装

Hbase软件版本下载地址&#xff1a; http://mirror.bit.edu.cn/apache/hbase/ 1. 集群环境 Master 172.16.11.97 Slave1 172.16.11.98 Slave2 172.16.11.99 2. 下载软件包 #Master wget http://archive.apache.org/dist/hbase/0.98.24/hbase-0.98.24-hadoop1-bin.tar.gz…

人工智能ACA(四)--机器学习基础

零、参考资料 一篇文章完全搞懂正则化&#xff08;Regularization&#xff09;-CSDN博客 一、 机器学习概述 0. 机器学习的层次结构 学习范式&#xff08;最高层&#xff09; 怎么学 监督学习 无监督学习 半监督学习 强化学习 学习任务&#xff08;中间层&#xff0…

HTML语法规范

HTML语法规则 HTML 标签是由尖括号包围的关键词&#xff0c;标签通常是成对出现的&#xff0c;例如 <html> 和 </html>&#xff0c;称为双标签 。标签对中的第一个标签是开始标签&#xff0c;第二个标签是结束标签单标签比较少&#xff0c;例如<br />&#x…

四川托普信息技术职业学院教案1

四川托普信息技术职业学院教案 【计科系】 周次 第 1周&#xff0c;第1次课 备 注 章节名称 第1章 XML语言简介 引言 1.1 HTML与标记语言 1.2 XML的来源 1.3 XML的制定目标 1.4 XML概述 1.5 有了HTML了&#xff0c;为什么还要发展XML 1.5.1 HTML的缺点 1.5.2 XML的特点 1.6 X…

Win10将WindowsTerminal设置默认终端并添加到右键(无法使用微软商店)

由于公司内网限制&#xff0c;无法通过微软商店安装 Windows Terminal&#xff0c;本指南提供手动安装和配置新版 Windows Terminal 的步骤&#xff0c;并添加右键菜单快捷方式。 1. 下载新版终端安装包: 访问 Windows Terminal 的 GitHub 发布页面&#xff1a;https://githu…

OpenAI发布新一代推理模型O3和O3 Mini:能力与性能的双重突破

2024年12月21日&#xff0c;OpenAI通过一场特别活动正式宣布了其新一代推理模型O3及其轻量化版本O3 Mini。这标志着AI推理能力和效率的又一次飞跃。本文将围绕发布会中的关键内容&#xff0c;详细介绍O3和O3 Mini的核心能力、性能表现、以及面向公众安全测试的相关计划。 1. 背…

VScode插件之get、set函数自动生成

文章目录 VScode插件之get、set函数自动生成插件名称现有功能功能快捷键使用总结与部分插件的get、set生成对比部分实现效果展示部分实现思路 VScode插件之get、set函数自动生成 初次尝试插件的编写开发&#xff0c;这篇博客也是对自己成果的一个记录&#xff0c;如有不足请指…

【Lua热更新】上篇

Lua 热更新 - 上篇 下篇链接&#xff1a;【Lua热更新】下篇 文章目录 Lua 热更新 - 上篇一、AssetBundle1.理论2. AB包资源加载 二、Lua 语法1. 简单数据类型2.字符串操作3.运算符4.条件分支语句5.循环语句6.函数7. table数组8.迭代器遍历9.复杂数据类型 - 表9.1字典9.2类9.3…

完全二叉树的权值(蓝桥杯2019年试题G)

给定一棵包含N个节点的完全二叉树&#xff0c;树上的每个节点都有一个权值&#xff0c;按从上到小、从左到右的顺序依次是A1、A2……An,&#xff08;1&#xff0c;2&#xff0c;n为下标。&#xff09;如下图所示。 现在&#xff0c;小明要把相同深度的节点的权值加到一起&#…

时间管理系统|Java|SSM|JSP|

【技术栈】 1⃣️&#xff1a;架构: B/S、MVC 2⃣️&#xff1a;系统环境&#xff1a;Windowsh/Mac 3⃣️&#xff1a;开发环境&#xff1a;IDEA、JDK1.8、Maven、Mysql5.7 4⃣️&#xff1a;技术栈&#xff1a;Java、Mysql、SSM、Mybatis-Plus、JSP、jquery,html 5⃣️数据库可…

前端yarn工具打包时网络连接问题排查与解决

最近线上前端打包时提示 “There appears to be trouble with your network connection”&#xff0c;以此文档记录下排查过程。 前端打包方式 docker启动临时容器打包&#xff0c;命令如下 docker run --rm -w /app -v pwd:/app alpine-node-common:v16.20-pro sh -c "…