
php-fpm 的 pm.max_children 不是随便填的数字
它直接决定单个 php-fpm worker 进程能并发处理多少请求,填大了 OOM,填小了压测直接 502。关键不是看 CPU 核数,而是看每个 PHP 请求平均吃多少内存。
- 先用
ps aux --sort=-%mem | grep 'php-fpm' | head -10看几个活跃 worker 的RSS值(单位 KB),取稳定后的典型值,比如 42MB →43008 - 查服务器可用内存:用
free -m看available列,比如剩 1980MB,再减掉系统、MySQL、Redis 等常驻进程保守预留 512MB → 剩约1468MB - 计算:
pm.max_children = floor(1468 * 1024 / 43008) ≈ 35;别四舍五入,向下取整 - 上线后盯
pm.status_path输出里的processes和max active processes,如果长期接近pm.max_children,说明真不够用了
PHP 8.5 + fpm 下 pm 模式选 static 还是 dynamic?
8.5 没新增调度逻辑,但 JIT 和 OPCache 默认更激进,worker 启动后内存增长比 7.4 更明显——这会让 dynamic 模式下 pm.max_children 实际意义变弱。
-
static:所有 worker 一启动就分配满内存,pm.max_children就是硬上限,适合流量平稳、内存充裕的 API 服务 -
dynamic:依赖pm.start_servers/pm.min_spare_servers/pm.max_spare_servers,但 PHP 8.5 下 worker 内存“越跑越大”,pm.max_spare_servers高了容易触发 OOM killer - 真实场景建议:Nginx + PHP-FPM 跑 WordPress 或 Laravel?用
dynamic,但把pm.max_spare_servers设成和pm.max_children相同,等于事实静态化,避免抖动
pm.max_children 设太高触发 OOM Killer 的典型现象
不是报错,是进程被静默杀掉,然后 systemctl status php8.5-fpm 显示 “killed by signal 9”,dmesg -T | tail 里有 “Out of memory: Kill process php-fpm (PID XXXX) score YY”。
BJXSHOP购物管理系统是一个功能完善、展示信息丰富的电子商店销售平台;针对企业与个人的网上销售系统;开放式远程商店管理;完善的订单管理、销售统计、结算系统;强力搜索引擎支持;提供网上多种在线支付方式解决方案;强大的技术应用能力和网络安全系统 BJXSHOP网上购物系统 - 书店版,它具备其他通用购物系统不同的功能,有针对图书销售而进行开发的一个电子商店销售平台,如图书ISBN,图书目录
- 别只看
free -m,Linux 的available是估算值,实际 OOM 常发生在MemAvailable低于 100MB 时 -
pm.max_children× 单 worker RSS > 总物理内存 × 0.85,风险极高;超过 0.9 基本等死 - 检查
/proc/sys/vm/overcommit_memory:值为2时内核更激进回收,但 PHP 8.5 的 JIT 编译缓存会锁住大量匿名页,导致回收失败率上升
PHP 8.5 必须调的配套参数,否则 pm.max_children 算得再准也白搭
JIT 和 OPCache 在 8.5 是默认开启的,它们吃内存不走 memory_limit,而是直吞 RSS,算 pm.max_children 时漏掉这部分,结果就是“明明按 42MB 算的,怎么跑两天就 OOM?”
立即学习“PHP免费学习笔记(深入)”;
- 关掉 JIT(最稳):
opcache.jit=off,或设保守值:opcache.jit=1235(只做函数调用优化,不开循环优化) - 限制 OPCache 共享内存:
opcache.memory_consumption=128(单位 MB),别用默认 256 - 加一句
pm.process_idle_timeout=10s(dynamic模式下),防空闲 worker 占着内存不放 - 确认
memory_limit设的是256M这种带单位的字符串,不是256(PHP 8.5 会当字节解析,等于 256B)
算 pm.max_children 的时候,最容易被忽略的是 OPCache 和 JIT 的内存“暗账”——它们不报错、不超限、不释放,就安静地把 RSS 顶上去,直到 OOM Killer 出手。










