0

0

PHP如何做请求限流_控制高并发访问量的方法汇总【指南】

蓮花仙者

蓮花仙者

发布时间:2026-02-21 18:57:09

|

910人浏览过

|

来源于php中文网

原创

redis滑动窗口限流需用lua脚本保证原子性,基于zset维护时间戳并清理过期数据,避免incr+expire竞态;ip限流须校验可信代理头,优先使用user_id;nginx层limit_req更高效,php层适合细粒度策略。

php如何做请求限流_控制高并发访问量的方法汇总【指南】

Redis 实现滑动窗口限流最实用

直接上生产环境能扛住每秒几百请求的方案,不是靠 PHP 自己计数,而是借 Redis 的原子操作和过期机制。关键在于避免用 INCR + EXPIRE 两步走——中间可能被并发打断,必须用 Lua 脚本保证原子性。

常见错误是把时间窗口设成固定整点(比如每分钟从 :00 开始),导致流量在窗口切换时突增一倍。正确做法是滑动窗口:每次请求都检查「过去 N 秒内」的请求数,不依赖绝对时间点。

  • EVAL 执行 Lua 脚本,传入 key、窗口秒数、最大请求数三个参数
  • 脚本里用 zremrangebyscore 清理过期时间戳,再用 zcard 统计当前窗口请求数
  • 如果未超限,用 zadd 写入当前毫秒时间戳,并设 key 过期时间为窗口长度 + 1 秒(防残留)
  • PHP 中推荐用 Predis 客户端,它对 Lua 脚本支持稳定,比原生 phprediseval 方法更少出错

$_SERVER['REMOTE_ADDR'] 做 IP 限流要小心代理

直接拿 $_SERVER['REMOTE_ADDR'] 当用户标识,在有 CDN 或 Nginx 反向代理的环境下会全部变成 127.0.0.1 或网关 IP。必须配合 X-Forwarded-ForX-Real-IP 头,但不能无条件信任——这些头可被客户端伪造。

安全做法是只信任你可控的上游代理 IP 段。例如 Nginx 在 proxy_set_header X-Real-IP $remote_addr; 前加了 set_real_ip_from 10.0.0.0/8;,那 PHP 里就得先判断 $_SERVER['REMOTE_ADDR'] 是否在该段内,再取 $_SERVER['HTTP_X_REAL_IP']

立即学习PHP免费学习笔记(深入)”;

Cleanup.pictures
Cleanup.pictures

智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

下载
  • 永远不要用 $_SERVER['HTTP_X_FORWARDED_FOR'] 的第一个值,它可能被拼接多个 IP,要 split 后取最后一个可信段
  • 如果业务允许,优先用登录态 user_id 代替 IP 限流,更精准且防绕过
  • 注意 IPv6 地址格式(含冒号和缩写),用 inet_pton()inet_ntop() 标准化后再做 key 拼接

token bucket 算法在 PHP 里怎么落地

令牌桶适合需要平滑放行、允许短时突发的场景(比如 API 调用配额)。难点不在算法逻辑,而在“桶”状态的跨请求持久化——不能存在 PHP 进程内存里,得存 Redis 或数据库。

核心字段就两个:当前令牌数 tokens、上次补充时间 last_refill。每次请求先算出到当前时刻该补多少令牌(rate × elapsed),再更新 tokens,最后判断是否 ≥1。

  • HGETALL 读桶状态,用 HSET + EXPIRE 写回,但要注意竞态:两个请求同时读到旧 tokens,各自计算后写回,会丢失一次补充
  • 解决方法是改用 Lua 脚本,把读、算、写三步锁死;或者直接用 RedisINCRBYFLOAT 配合 GETSET 模拟 CAS
  • 桶容量别设太大(比如 >1000),否则 Redis 中浮点精度误差会导致令牌数异常

Apache / Nginx 层限流比 PHP 更早生效

PHP 层限流本质是“请求已进应用”,CPU 和内存已被占用。真正要挡在最外层,得靠 Web 服务器配置。Nginx 的 limit_req 模块比 PHP 方案快一个数量级,且不依赖应用代码。

典型配置里容易踩的坑是没配 burstnodelay:只写 limit_req zone=api burst=5; 会让超出的请求排队,等前面处理完才放行,实际延迟飙升;加 nodelay 才是严格限速,超了直接 503。

  • key 用 $binary_remote_addr 而不是 $remote_addr,节省 Redis 内存(IPv4 固定 4 字节,IPv6 固定 16 字节)
  • Apache 用户可用 mod_ratelimit,但功能弱于 Nginx,仅支持响应体限速,不适用于请求频率控制
  • 注意 Nginx 共享内存区大小:limit_req_zonezone=api:10m 最多存约 16 万个 IP,高并发下不够用会静默失效

限流不是加个 if 判断就完事,关键在状态一致性、边界识别和层级协作。越靠近客户端的拦截越有效,但越难做细粒度策略;PHP 层适合按用户身份、接口类型做差异化控制,别让它承担本该由基础设施干的活。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

517

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

566

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

242

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

541

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3606

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

49

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

67

2026.01.13

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

928

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号