合 PHP优化扩展OPcache
简介
OPcache 通过将 PHP 脚本预编译的字节码(Operate Code)存储到共享内存中来提升 PHP 的性能, 存储预编译字节码的好处就是 省去了每次加载和解析 PHP 脚本的开销。
PHP 5.5.0 及后续版本中已经绑定了 OPcache 扩展。 对于 PHP 5.2,5.3 和 5.4 版本可以使用 » PECL 扩展中的 OPcache 库。
Opcode cache 的目地是避免重复编译,减少 CPU 和内存开销。
运行时配置
这些函数的行为受 php.ini 中的设置影响。
名字 | 默认 | 可修改范围 | 更新日志 |
---|---|---|---|
opcache.enable | "1" | PHP_INI_ALL | |
opcache.enable_cli | "0" | PHP_INI_SYSTEM | 在 PHP 7.1.2 至 7.1.6 (含)的版本,默认值是"1" |
opcache.memory_consumption | "128" | PHP_INI_SYSTEM | 在 PHP 7.0.0 之前,默认值是 "64" |
opcache.interned_strings_buffer | "8" | PHP_INI_SYSTEM | 在 PHP 7.0.0 之前,默认值是 "4" |
opcache.max_accelerated_files | "10000" | PHP_INI_SYSTEM | 在 PHP 7.0.0 之前,默认值是 "2000" |
opcache.max_wasted_percentage | "5" | PHP_INI_SYSTEM | |
opcache.use_cwd | "1" | PHP_INI_SYSTEM | |
opcache.validate_timestamps | "1" | PHP_INI_ALL | |
opcache.revalidate_freq | "2" | PHP_INI_ALL | |
opcache.revalidate_path | "0" | PHP_INI_ALL | |
opcache.save_comments | "1" | PHP_INI_SYSTEM | |
opcache.load_comments | "1" | PHP_INI_ALL | 从 PHP 7.0.0 开始被移除 |
opcache.fast_shutdown | "0" | PHP_INI_SYSTEM | 从 PHP 7.2.0 开始被移除 |
opcache.enable_file_override | "0" | PHP_INI_SYSTEM | |
opcache.optimization_level | "0x7FFFBFFF" | PHP_INI_SYSTEM | 从 PHP 5.6.18 开始,默认值从 0xFFFFFFFF 修改为 0x7FFFBFFF |
opcache.inherited_hack | "1" | PHP_INI_SYSTEM | 自 PHP 7.3.0 被移除 |
opcache.dups_fix | "0" | PHP_INI_ALL | |
opcache.blacklist_filename | "" | PHP_INI_SYSTEM | |
opcache.max_file_size | "0" | PHP_INI_SYSTEM | |
opcache.consistency_checks | "0" | PHP_INI_ALL | |
opcache.force_restart_timeout | "180" | PHP_INI_SYSTEM | |
opcache.error_log | "" | PHP_INI_SYSTEM | |
opcache.log_verbosity_level | "1" | PHP_INI_SYSTEM | |
opcache.preferred_memory_model | "" | PHP_INI_SYSTEM | |
opcache.protect_memory | "0" | PHP_INI_SYSTEM | |
opcache.mmap_base | null | PHP_INI_SYSTEM | |
opcache.restrict_api | "" | PHP_INI_SYSTEM | |
opcache.file_update_protection | "2" | PHP_INI_ALL | |
opcache.huge_code_pages | "0" | PHP_INI_SYSTEM | |
opcache.lockfile_path | "/tmp" | PHP_INI_SYSTEM | |
opcache.opt_debug_level | "0" | PHP_INI_SYSTEM | |
opcache.file_cache | NULL | PHP_INI_SYSTEM | 从 PHP 7.0.0 开始支持 |
opcache.file_cache_only | "0" | PHP_INI_SYSTEM | 从 PHP 7.0.0 开始支持 |
opcache.file_cache_consistency_checks | "1" | PHP_INI_SYSTEM | 从 PHP 7.0.0 开始支持 |
opcache.file_cache_fallback | "1" | PHP_INI_SYSTEM | 从 PHP 7.0.0 开始支持,仅适用于 Windows 平台 |
opcache.validate_permission | "0" | PHP_INI_SYSTEM | 从 PHP 7.0.14 开始支持 |
opcache.validate_root | "0" | PHP_INI_SYSTEM | 从 PHP 7.0.14 开始支持 |
opcache.preload | "" | PHP_INI_SYSTEM | 从 PHP 7.4.0 开始支持 |
opcache.preload_user | "" | PHP_INI_SYSTEM | 从 PHP 7.4.0 开始支持 |
有关 PHPINI* 样式的更多详情与定义,见 配置可被设定范围。
这是配置指令的简短说明。
opcache.enable
boolean启用操作码缓存。如果禁用此选项,则不会优化和缓存代码。 在运行期使用 ini_set() 函数只能禁用
opcache.enable
设置,不可以启用此设置。 如果在脚本中尝试启用此设置项会产生警告。opcache.enable_cli
boolean仅针对 CLI 版本的 PHP 启用操作码缓存。 通常被用来测试和调试。
opcache.memory_consumption
integerOPcache 的共享内存大小,以兆字节为单位。
opcache.interned_strings_buffer
integer用来存储预留字符串的内存大小,以兆字节为单位。 PHP 5.3.0 之前的版本会忽略此配置指令。
opcache.max_accelerated_files
integerOPcache 哈希表中可存储的脚本文件数量上限。 真实的取值是在质数集合
{ 223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987 }
中找到的第一个大于等于设置值的质数。 设置值取值范围最小值是 200,最大值在 PHP 5.5.6 之前是 100000,PHP 5.5.6 及之后是 1000000。opcache.max_wasted_percentage
integer浪费内存的上限,以百分比计。 如果达到此上限,那么 OPcache 将产生重新启动续发事件。
opcache.use_cwd
boolean如果启用,OPcache 将在哈希表的脚本键之后附加改脚本的工作目录, 以避免同名脚本冲突的问题。 禁用此选项可以提高性能,但是可能会导致应用崩溃。
opcache.validate_timestamps
boolean如果启用,那么 OPcache 会每隔 opcache.revalidate_freq 设定的秒数 检查脚本是否更新。 如果禁用此选项,你必须使用 opcache_reset()或者 opcache_invalidate() 函数来手动重置 OPcache,也可以 通过重启 Web 服务器来使文件系统更改生效。
opcache.revalidate_freq
integer检查脚本时间戳是否有更新的周期,以秒为单位。 设置为
0
会导致针对每个请求, OPcache 都会检查脚本更新。如果 opcache.validate_timestamps 配置指令设置为禁用,那么此设置项将会被忽略。opcache.revalidate_path
boolean如果禁用此选项,在同一个 include_path 已存在的缓存文件会被重用。 因此,将无法找到不在包含路径下的同名文件。
opcache.save_comments
boolean如果禁用,脚本文件中的注释内容将不会被包含到操作码缓存文件, 这样可以有效减小优化后的文件体积。 禁用此配置指令可能会导致一些依赖注释或注解的 应用或框架无法正常工作, 比如: Doctrine, Zend Framework 2 以及 PHPUnit。
opcache.load_comments
boolean如果禁用,则即使文件中包含注释,也不会加载这些注释内容。 本选项可以和 opcache.save_comments 一起使用,以实现按需加载注释内容。
opcache.fast_shutdown
boolean如果启用,则会使用快速停止续发事件。 所谓快速停止续发事件是指依赖 Zend 引擎的内存管理模块 一次释放全部请求变量的内存,而不是依次释放每一个已分配的内存块。从 PHP 7.2.0 开始,此配置指令被移除。 快速停止的续发事件的处理已经集成到 PHP 中, 只要有可能,PHP 会自动处理这些续发事件。
opcache.enable_file_override
boolean如果启用,则在调用函数 file_exists(), is_file() 以及 is_readable() 的时候, 都会检查操作码缓存,无论文件是否已经被缓存。 如果应用中包含检查 PHP 脚本存在性和可读性的功能,这样可以提升性能。 但是如果禁用了 opcache.validate_timestamps 选项, 可能存在返回过时数据的风险。
opcache.optimization_level
integer控制优化级别的二进制位掩码。
opcache.inherited_hack
boolean该配置指令已被忽略。
opcache.dups_fix
boolean仅作为针对 “不可重定义类”错误的一种解决方案。
opcache.blacklist_filename
stringOPcache 黑名单文件位置。 黑名单文件为文本文件,包含了不进行预编译优化的文件名,每行一个文件名。 黑名单中的文件名可以使用通配符,也可以使用前缀。 此文件中以分号(;)开头的行将被视为注释。
简单的黑名单文件可能如下所示:
本人提供Oracle(OCP、OCM)、MySQL(OCP)、PostgreSQL(PGCA、PGCE、PGCM)等数据库的培训和考证业务,私聊QQ646634621或微信dbaup66,谢谢!