时间:2020-09-27来源:www.pcxitongcheng.com作者:电脑系统城
我们先看一下 PHP 的执行过程:
在 PHP-FPM 模式下,步骤 1 在启动时执行一次,后续的请求中不再执行;步骤 2 3 4每次请求都需要执行一遍。
2 和 3 生成的语法树和 Opcode ,同一个PHP 脚本每次运行的结果都是一样的。
而 OPcache 就是用来缓存 Opcode 的。
OPCache 是 Zend 官方出品的,开放自由的 Opcode 缓存扩展,还具有代码优化功能,省去每次加载和解析 PHP 脚本的开销。
OPcache 通过将 PHP 脚本预编译的字节码存储到共享内存中来提升 PHP 的性能, 存储预编译字节码的好处就是 省去了每次加载和解析 PHP 脚本的开销。
PHP5.5.0以后的版本已经默认包含了 OPCache 扩展。
OPCache 缓存的机制主要是:将 PHP 编译产生的字节码以及数据缓存到共享内存中,在每次请求,从缓存中直接读取编译后的 opcode,进行执行。
是缓存,都有过期时间。
OPCache 的更新策略非常简单,到期数据置为 Wasted,达到设定值,清空缓存,重建缓存。
因为在高流量的场景下,重建缓存是一件非常耗费资源的事情,所以建议:不要设置 OPcache 的过期时间。
每次发布新代码时,都会出现反复新建缓存的情况。如何避免呢?
opcache_compile_file()
进行编译缓存因为PHP5.5.0 以后的版本都已经默认安装了 OPCache,但是默认是没有开启的,需要手动开启。
开发方法:编辑 php.ini
Copy
;开启扩展 zend_extension=opcache.so [opcache] ;允许在 web 环境使用 opcache.enable=1 ;允许在 cli 环境使用 opcache.enable_cli=0
重启 PHP-FPM 和 Nginx。
Copy
service php7.2-fpm restart service nginx restart
php.ini
的 OPCache 配置#Copy
;允许在 web 环境使用 opcache.enable=1 ;允许在 cli 环境使用 opcache.enable_cli=1 ;OPcache 的共享内存大小,以兆字节为单位。 opcache.memory_consumption=128 ;用来存储预留字符串的内存大小,以兆字节为单位 opcache.interned_strings_buffer=8 ;OPcache 哈希表中可存储的脚本文件数量上限 opcache.max_accelerated_files=4000 ;检查脚本时间戳是否有更新的周期,以秒为单位。 设置为 0 会导致针对每个请求, OPcache 都会检查脚本更新。如果 opcache.validate_timestamps 配置指令设置为禁用,那么此设置项将会被忽略。 opcache.revalidate_freq=60
2023-03-15
Navicat远程连接MongoDB最全实现方法以及报错解决2023-03-15
MongoDB的启动方法详细总结2023-03-11
详解分库分表后非分片键如何查询GROUP BY 语句用于结合合计函数,根据一个或多个列对结果集进行分组,下面这篇文章主要给大家介绍了关于高版本Mysql使用group by分组报错的解决方案,文中通过实例代码介绍的非常详细,需要的朋友可以参考下...
2023-03-06