PHP 8.4 尚未发布,JIT 自 PHP 8.0 起已内置但默认未启用;开启需正确配置 opcache.jit=1255、opcache.jit_buffer_size、opcache.enable 等参数,并禁用 Xdebug。
PHP 8.4 尚未发布(截至 2025 年 7 月,最新稳定版是 PHP 8.3),因此 php-8.4 中并不存在 JIT 编译功能的“新开启方式”——JIT 自 PHP 8.0 起已内置,但默认**未启用**,且在 8.1–8.3 中行为一致;8.4 也大概率延续该设计。所谓“PHP 8.4 开启 JIT”,本质仍是配置 PHP 8.0+ 的现有 JIT 机制。
最常见原因是:JIT 依赖 OPcache 完全启用,而很多环境只开了 opcache.enable=1,却漏掉了关键前提:
opcache.enable_cli=0(CLI 模式默认禁用 OPcache,JIT 在 CLI 下无效)opcache.jit_buffer_size=64M(必须设为非零值,否则 JIT 不启动)opcache.revalidate_freq=0(开发时建议设为 0,否则脚本修改后 JIT 代码可能不刷新)opcac
he.memory_consumption 过小或系统 shm 限制不足)典型有效组合(适用于 Web SAPI,如 Apache/FPM):
opcache.enable=1 opcache.enable_cli=0 opcache.memory_consumption=256 opcache.jit_buffer_size=64M opcache.jit=1255
opcache.jit 是位掩码参数,1255 是十进制写法,对应二进制 10011100111,含义是:function(函数级编译) + tracing(追踪模式) + register(寄存器分配) + loop(循环优化)。它比纯 tracing 更激进,但也更耗内存、启动稍慢。
opcache.jit=1205(去掉 register,平衡稳定性与性能)opcache.jit=tracing 是可读写法,等价于 1205,但某些旧版本 ini 解析器不支持字符串形式phpinfo() 页面中 “OPcache JIT” 行,显示 “enabled” 且 “JIT buffer size” > 0 才算成功实际收益有限。JIT 主要加速 CPU 密集型长循环和数学运算,而主流 PHP 应用瓶颈通常在 I/O(数据库、Redis、HTTP 请求)、 autoload、模板渲染等环节。
JIT 会生成机器码并缓存,对内存和 CPU 架构敏感。以下问题高频出现:
opcache.jit_buffer_size=256M 导致 PHP-FPM worker 内存超限(尤其低配 VPS)→ 改回 64M 或 32M
php -v 是否含 with Zend OPcache JIT,确认构建时启用了 --enable-opcache-jit
xdebug)与 JIT 冲突 → 必须禁用 Xdebug(zend_extension= 行注释掉),JIT 和 Xdebug 不能共存opcache.jit_debug=1 可输出 JIT 日志,但仅用于调试,切勿开在生产环境JIT 不是银弹。它让部分代码路径更快,但也增加内存占用、降低启动速度、提高调试复杂度。上线前务必在压测环境对比 ab 或 wrk 的 QPS 和 99% 延迟,而不是只看 phpbench 数值。