首先确认 php 版本并检查 OPcache 支持情况,使用 php - v 和 php -m | grep opcache 命令;接着通过 php –ini 找到 配置文件 路径,在 php.ini 中设置 opcache.enable=1;然后优化关键参数如 memory_consumption、max_accelerated_files 等;之后重启 apache 或nginx与 PHP-FPM 服务;最后创建 phpinfo 页面验证 OPcache 是否启用成功且正常运行。

如果您在配置 PHP 环境时发现页面加载速度较慢,可能是由于未启用 OPcache 扩展导致的。OPcache 通过将预编译的脚本存储在共享内存中,避免重复编译,从而提升 PHP 执行效率。以下是启用 OPcache 扩展的具体步骤。
本文运行环境:Dell XPS 13,ubuntu 22.04
一、确认 PHP 版本及 OPcache 支持情况
在启用 OPcache 之前,需要确认当前 PHP 版本是否支持该扩展,并检查其是否已安装但未启用。大多数 PHP 5.5 及以上版本默认包含 OPcache 扩展。
1、打开终端,输入命令php -v,查看当前 PHP 版本信息。
立即学习“PHP 免费学习笔记(深入)”;
2、运行php -m | grep opcache,检查 OPcache 模块是否已在加载的模块列表中。
3、若无输出,则说明 OPcache 未启用或未安装;若有 opcache 字样,则只需修改 配置文件 激活即可。
二、编辑 php.ini 配置文件启用 OPcache
OPcache 的启用依赖于 php.ini 中的配置项。找到正确的 php.ini 文件并添加或修改相关参数是关键步骤。
1、使用命令 php –ini 查看当前加载的 php.ini 文件路径。
2、用文本编辑器打开该文件,例如:sudo nano /etc/php/8.1/apache2/php.ini(路径根据实际版本和服务器类型可能不同)。
3、在文件中查找opcache.enable,将其值设为1;若不存在,则手动添加如下行:
opcache.enable=1
4、保存并关闭文件。
三、配置关键 OPcache 参数以优化性能
仅启用 OPcache 不足以发挥最佳性能,需调整核心参数以适应应用需求。
1、在 php.ini 文件中添加或修改以下配置项:
opcache.memory_consumption=128
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=4000
opcache.revalidate_freq=60
opcache.fast_shutdown=1
2、memory_consumption 定义分配给 OPcache 的内存大小,单位为 MB,建议设置为 128 以上。
3、max_accelerated_files 表示可缓存的最大文件数,应根据项目规模适当增加。
4、完成配置后保存文件。
四、重启 Web 服务器使配置生效
修改 php.ini 后必须重启 Web 服务进程,才能加载新的 OPcache 设置。
1、如果使用 Apache,执行命令:sudo systemctl restart apache2。
2、如果使用 Nginx 配合 PHP-FPM,执行:sudo systemctl restart php8.1-fpm(版本号需匹配)。
3、同时重启 Nginx:sudo systemctl restart nginx。
五、验证 OPcache 是否正常运行
通过创建一个 PHP 信息页来确认 OPcache 是否成功启用并正常工作。
1、创建一个名为 info.php 的文件,内容为<?php phpinfo(); ?>,放置于 Web 根目录下。
2、在 浏览器 中访问http://localhost/info.php。
3、搜索“OPcache”关键字,确认看到 OPcache 信息表格且“Opcode Cache”状态为“Enabled”。
4、检查“Cached Scripts”数量随页面请求变化,证明缓存机制正在运行。


