【Nginx-5】Nginx 限流配置指南:保护你的服务器免受流量洪峰冲击
在现代互联网应用中,流量波动是常态。无论是突发的用户访问高峰,还是恶意攻击,都可能导致服务器资源耗尽,进而影响服务的可用性。为了应对这种情况,限流(Rate Limiting)成为了一种常见的保护措施。Nginx 作为一款高性能的 Web 服务器和反向代理服务器,提供了强大的限流功能,可以帮助我们有效控制流量,保护后端服务。
1. 为什么需要限流?
在讨论如何配置限流之前,我们先来了解一下为什么需要限流。
- 防止服务器过载:当流量突然激增时,服务器可能会因为处理不过来而崩溃。限流可以限制单位时间内的请求数量,避免服务器过载。
- 防止恶意攻击:某些恶意用户或攻击者可能会通过大量的请求来消耗服务器资源,导致正常用户无法访问。限流可以有效抵御这种攻击。
- 保障服务质量:通过限流,可以确保核心业务在流量高峰期仍然能够正常运行,避免因为流量激增而导致服务质量下降。
2. Nginx 限流的基本概念
Nginx 提供了两种主要的限流方式:
- 基于请求速率的限流(Rate Limiting):限制单位时间内的请求数量。
- 基于连接数的限流(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
指令用于在具体的 location
或 server
块中应用请求速率限流策略。
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
指令用于在具体的 location
或 server
块中应用连接数限流策略。
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_zone
和 limit_req
指令,你可以有效地控制请求速率;通过配置 limit_conn_zone
和 limit_conn
指令,你可以限制同时处理的连接数。
在实际应用中,限流策略需要根据具体的业务需求进行调整。你可以通过增加 burst
值、使用自定义变量、处理代理后的客户端 IP 等方式来优化限流配置,确保限流策略既能保护服务器,又不会误伤正常用户。
相关文章:

【Nginx-5】Nginx 限流配置指南:保护你的服务器免受流量洪峰冲击
在现代互联网应用中,流量波动是常态。无论是突发的用户访问高峰,还是恶意攻击,都可能导致服务器资源耗尽,进而影响服务的可用性。为了应对这种情况,限流(Rate Limiting)成为了一种常见的保护措施…...

【芯片设计- RTL 数字逻辑设计入门 番外篇 7.1 -- 基于ATE的IC测试原理】
文章目录 ATE 测试概述Opens/Shorts测试Leakage测试AC测试转自:漫谈大千世界 漫谈大千世界 2024年10月23日 23:17 湖北 ATE 测试概述 ATE(Automatic Test Equipment)是用于检测集成电路(IC)功能完整性的自动测试设备。它在半导体产业中扮演着至关重要的角色,主要用于检…...

SurfaceFlinger 学习
Android 图形系统之七:SurfaceFlinger-CSDN博客 CSDN...

Flink SQL 从一个SOURCE 写入多个Sink端实例
一. 背景 FLINK 任务从一个数据源读取数据, 写入多个sink端. 二. 官方实例 写入多个Sink语句时,需要以BEGIN STATEMENT SET;开头,以END;结尾。--源表 CREATE TEMPORARY TABLE datagen_source (name VARCHAR,score BIGINT ) WITH (connector datagen …...

python飞机大战游戏.py
python飞机大战游戏.py import pygame import random# 游戏窗口大小 WINDOW_WIDTH 600 WINDOW_HEIGHT 800# 颜色定义 BLACK (0, 0, 0) WHITE (255, 255, 255)# 初始化Pygame pygame.init()# 创建游戏窗口 window pygame.display.set_mode((WINDOW_WIDTH, WINDOW_HEIGHT))…...

【C++】14___String容器
目录 一、string基本概念 二、string赋值操作 三、字符串拼接 四、 string查找和替换 五、 string字符串比较 六、string插入和删除 七、string子串 一、string基本概念 本质:string是C风格的字符串,而string本质上是一个类 string和char*区别&am…...

数据特性库 前言
文章目录 一、num-traits库简介二、核心功能三、更新功能四、使用方式五、应用示例六、结论 一、num-traits库简介 num-traits是Rust编程语言中的一个开源库,专注于为数值类型提供一系列的数学运算特性和接口。它支持泛型数学计算,允许开发者在不指定具…...

jdk和cglib动态代理区别
目标类不同 jdk目标类需要实现接口。 cglib不需要。 代理类生成方式不同 jdk内部字节码生成代理类。 cglib使用ASM字节码生成库生成代理类。 代理类和目标类关系不同 jdk代理类实现目标类接口,jdk无法代理目标类中static或private的方法。 cglib 代理类继承目标类…...

部署Mysql、镜像和容器、常见命令
目录 部署Mysql 镜像和容器 常见命令 部署Mysql 可以有多个容器 docker run -d \--name mysql \-p 3306:3306 \-e TZAsia/Shanghai \-e MYSQL_ROOT_PASSWORD123 \mysql docker run -d \--name mysql2 \-p 3307:3307 \-e TZAsia/Shanghai \-e MYSQL_ROOT_PASSWORD123 \mys…...

【数学】P2671 [NOIP2015 普及组] 求和
题目背景 NOIP2015 普及组 T3、深入浅出进阶1-5 题目描述 一条狭长的纸带被均匀划分出了 n n n 个格子,格子编号从 1 1 1 到 n n n。每个格子上都染了一种颜色 c o l o r i color_i colori 用 [ 1 , m ] [1,m] [1,m] 当中的一个整数表示)&…...

【AI图像生成网站Golang】项目测试与优化
AI图像生成网站 目录 一、项目介绍 二、雪花算法 三、JWT认证与令牌桶算法 四、项目架构 五、图床上传与图像生成API搭建 六、项目测试与优化 六、项目测试与优化 在开发过程中,性能优化是保证项目可扩展性和用户体验的关键步骤。本文将详细介绍我如何使用一…...

vue常用自定义指令
参考链接1https://blog.csdn.net/m0_67584973/article/details/139300966?spm1001.2014.3001.5501 参考链接2https://juejin.cn/post/7067051410671534116...

以太网帧、IP数据报图解
注:本文为 “以太网帧、IP数据报”图解相关文章合辑。 未整理去重。 以太网帧、IP数据报的图解格式(包含相关例题讲解) Rebecca.Yan已于 2023-05-27 14:13:19 修改 一、基础知识 UDP 段、IP 数据包,以太网帧图示 通信过程中&…...

01.大模型起源与发展
知识点 注意力机制(Attention)的主要用途是什么? 选择重要的信息并忽略不相关的信息 Transformer 模型是基于什么理论构建的? C. 注意力机制(Attention) GPT 和 BERT 的主要区别是什么? C. GPT…...

leetcode刷题日记03——javascript
题目3: 回文数https://leetcode.cn/problems/palindrome-number/ 给你一个整数 x ,如果 x 是一个回文整数,返回 true ;否则,返回 false 。 回文数是指正序(从左向右)和倒序(从右向…...

vue横向滚动日期选择器组件
vue横向滚动日期选择器组件 组件使用到了element-plus组件库和dayjs库,使用前先保证项目中已经下载导入 主要功能:选择日期,点击日期可以让此日期滚动到视图中间,左滑右滑同理,支持跳转至任意日期,支持自…...

【大模型】大模型项目选择 RAGvs微调?
RAG 输入问题,在知识库匹配知识,构建提示词:基于{知识}回答{问题} 微调 用知识问答对重新训练大模型权重,输入问题到调整后的大模型 如何选择 如果业务要求较高,RAG和微调可以一起使用 1-动态数据 选择RAG 原因&a…...

2024年12月CCF-GESP编程能力等级认证Python编程一级真题解析
本文收录于专栏《Python等级认证CCF-GESP真题解析》,专栏总目录:点这里,订阅后可阅读专栏内所有文章。 一、单选题(每题 2 分,共 30 分) 第 1 题 2024年10月8日,诺贝尔物理学奖“意外地”颁给了两位计算机科学家约翰霍普菲尔德(John J. Hopfield)和杰弗里辛顿(Geof…...

【机器学习】元学习(Meta-learning)
云边有个稻草人-CSDN博客 目录 引言 一、元学习的基本概念 1.1 什么是元学习? 1.2 元学习的与少样本学习的关系 二、元学习的核心问题与挑战 2.1 核心问题 2.2 挑战 三、元学习的常见方法 3.1 基于优化的元学习 3.1.1 MAML(Model-Agnostic Meta…...

详解Redis的String类型及相关命令
目录 SET GET MGET MSET SETNX SET和SETNX和SETXX对比 INCR INCRBY DECR DECRBY INCRBYFLOAT APPEND GETRANGE SETRANGE STRLEN 内部编码 SET 将 string 类型的 value 设置到 key 中。如果 key 之前存在,则覆盖,⽆论原来的数据类型是什么…...

android RadioButton + ViewPager+fragment
RadioGroup viewpage fragment 组合显示导航栏 1、首先主界面的布局控件就是RadioGroup viewpage <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res/android"xmlns:tools…...

给机器装上“脑子”—— 一文带你玩转机器学习
目录 一、引言:AI浪潮中的明星——机器学习 二、机器学习的定义与概念 1. 机器学习与传统编程的区别 2. 机器学习的主要任务类型 3. 机器学习的重要组成部分 三、机器学习的工作原理:从数据到模型的魔法之旅 1. 数据收集与预处理——数据是机器的…...

论文笔记:是什么让多模态学习变得困难?
整理了What Makes Training Multi-modal Classification Networks Hard? 论文的阅读笔记 背景方法OGR基于最小化OGR的多监督信号混合在实践中的应用 实验 背景 直观上,多模态网络接收更多的信息,因此它应该匹配或优于其单峰网络。然而,最好的…...

ChatGPT Search开放:实时多模态搜索新体验
点击访问 chatTools 免费体验GPT最新模型,包括o1推理模型、GPT4o、Claude、Gemini等模型! ChatGPT Search:功能亮点解析 本次更新的ChatGPT Search带来了多项令人瞩目的功能,使其在搜索引擎市场中更具竞争力。 1. 高级语音模式&…...

Centos7.9 离线安装docker
实验环境: [root192 ~]# cat /etc/system-release CentOS Linux release 7.9.2009 (Core)下载二进制压缩包 a. 官网下载地址: https://download.docker.com/linux/static/stable/x86_64/b. 阿里云下载地址 https://mirrors.aliyun.com/docker-ce/lin…...

C语言函数在调用过程中具体是怎么和栈互动的?
从栈开始的一场C语言探险记 —— C语言函数是如何与栈"共舞"的。 栈的舞步解析 通过一个简单的例子来看看这支"舞蹈": int add(int a, int b) {int result a b;return result; }int main() {int x 10;int y 20;int sum add(x, y);retur…...

【Java中常见的异常及其处理方式】
🌈个人主页: Aileen_0v0 🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 💫个人格言:“没有罗马,那就自己创造罗马~” 文章目录 字符串修改的实现——StringBuilder和StringBuffer异常常见异常①算数异常②数组越界异常③空指针异…...

如何更新项目中的 npm 或 Yarn 依赖包至最新版本
要升级 package.json 文件中列出的包,你可以使用 npm(Node Package Manager)或 yarn。以下是两种工具的命令来更新你的依赖项: 使用 npm 更新所有包到最新版本 npm update如果你想将所有依赖项更新到其各自最新的大版本…...

SpringBoot3整合FastJSON2如何配置configureMessageConverters
在 Spring Boot 3 中整合 FastJSON 2 主要涉及到以下几个步骤,包括添加依赖、配置 FastJSON 作为 JSON 处理器等。下面是详细的步骤: 1. 添加依赖 首先,你需要在你的 pom.xml 文件中添加 FastJSON 2 的依赖。以下是 Maven 依赖的示例&#…...

《Vue3实战教程》2:Vue3快速上手
如果您有疑问,请观看视频教程《Vue3实战教程》 快速上手 线上尝试 Vue 想要快速体验 Vue,你可以直接试试我们的演练场。 如果你更喜欢不用任何构建的原始 HTML,可以使用 JSFiddle 入门。 如果你已经比较熟悉 Node.js 和构建工具等概念…...