大家知道目前PHP的缓存插件一般有三个:APC、eAccelerator、XCache,但未来它们可能都会消失,因为PHP 5.5已经集成Zend Opcache,功能和前三者相似但又有少许不同,缓存速度据说比它们更快(注意:只是据说,我没测试过)。
这几个PHP加速插件的主要原理都相同,就是把PHP执行后的数据缓冲到内存中从而避免重复的编译过程,能够直接使用缓冲区已编译的代码从而提高速度,降低服务器负载,它们的效率是显而易见的。
Zend Opcache在PHP 5.5后的版本中已经集成了,编译安装PHP5.5的时候加上--enable-opcache就行了,也支持低版本的 PHP 5.2.*, 5.3.*, 5.4.*,未来会取消对5.2的支持。
创新互联是由多位在大型网络公司、广告设计公司的优秀设计人员和策划人员组成的一个具有丰富经验的团队,其中包括网站策划、网页美工、网站程序员、网页设计师、平面广告设计师、网络营销人员及形象策划。承接:成都网站设计、成都做网站、网站改版、网页设计制作、网站建设与维护、网络推广、数据库开发,以高性价比制作企业网站、行业门户平台等全方位的服务。
如果在编译安装php5.5.34的时候,没有添加--enable-opcache参数,那么在php.ini中添加一些配置参数,启用即可,php5以后的版本中已经内置Zend Opcache,所以无需另外安装
cd /usr/local/php/lib
cp php.ini php.ini.bak #备份配置文件
vim php.ini,shfit+g到最后,添加如下配置
-----------------------------------------------------------------------------------------------------
[opcache]
zend_extension=opcache.so
opcache.interned_strings_buffer=8
opcache.fast_shutdown=1
opcache.enable_cli=1
opcache.enable=1
;可用内存,酌情而定,单位 megabytes
opcache.memory_consumption=128
;最大缓存的文件数目,命中率不到100%的话,可以试着提高这个值
opcache.max_accelerated_files=4000
;Opcache 会在一定时间内去检查文件的修改时间,这里设置检查的时间周期,默认为 2,单位为秒
opcache.revalidate_freq=60
------------------------------------------------------------------------------------------------------
如果是nginx环境,重启一下php-fpm进程即可
查看一下Zend Opcache是否启用
/usr/local/php/bin/php -v
最后一行带有 with Zend OPcache等字样 即表示启用
Opcache的配置参数详细解释如下:
名字 | 默认 | 可修改范围 | 含义 |
---|---|---|---|
opcache.enable | "1" | PHP_INI_ALL | 是否启用opcache |
opcache.enable_cli | "0" | PHP_INI_SYSTEM | 是否在CLI(即命令行时)启用opcache |
opcache.memory_consumption | "64" | PHP_INI_SYSTEM | 为opcache分配多少共享内存,单位M |
opcache.interned_strings_buffer | "4" | PHP_INI_SYSTEM | interned string的内存大小 |
opcache.max_accelerated_files | "2000" | PHP_INI_SYSTEM | 最大缓存的文件数目。 实际上这个值会使用第一个大于你配置的数字的下列素数 { 223, 463, 983, 1979, 3907, 7963, 16229, 32531, 65407, 130987 }, 如你将该值指定为400,则实际上该值为463. |
opcache.max_wasted_percentage | "5" | PHP_INI_SYSTEM | |
opcache.use_cwd | "1" | PHP_INI_SYSTEM | 如果置为1,则将当前路径加入到文件key中, 以避免可能产生的同文件名的文件key冲突 |
opcache.validate_timestamps | "1" | PHP_INI_ALL | 如果置为1,则OPCACHE会自动检测文件的时间戳 (检测周期为revalidate_freq), 并根据文件的时间戳来更新opcode,如果置为0, 则只能手动去重启opcache或 重启webserver以使更新后的php文件生效 |
opcache.revalidate_freq | "2" | PHP_INI_ALL | opcache自动检测文件是否更新的周期,单位秒。 如果是0,则每次请求时opcache都要进行检测。 当validate_timestamps为0时,本指令无效。 |
opcache.revalidate_path | "0" | PHP_INI_ALL | |
opcache.save_comments | "1" | PHP_INI_SYSTEM | 是否保存文件中的注释 |
opcache.load_comments | "1" | PHP_INI_ALL | 是否load comments,与save_comments联合起来使用, 如果该值为0,则即使save_comments为1, 那么php脚本中的comments也是不使用的 |
opcache.fast_shutdown | "0" | PHP_INI_SYSTEM | 是否打开快速关闭, 打开时可使php在request shutdown时回收内存快 |
opcache.enable_file_override | "0" | PHP_INI_SYSTEM | 如果置为1,则每次调用file_exist() is_file() is_readable()函数时, opcache将要检查该文件是否被cache了, 这样增加了检查存在性和可读性的开销, 但避免了当validate_timestamps为disable时返回错误文件状态的风险。 |
opcache.optimization_level | "0xffffffff" | PHP_INI_SYSTEM | 运行时控制优化的掩码(干什么的?) |
opcache.inherited_hack | "1" | PHP_INI_SYSTEM | 5.3以前使用。5.3后废弃 |
opcache.dups_fix | "0" | PHP_INI_ALL | 为解决“cannot redecllare class" 时,可将其置为1 |
opcache.blacklist_filename | "" | PHP_INI_SYSTEM | 设置黑名单文件,符合黑名单文件中定义的php文件将不被opcache。黑名单文件的例子如下: ; Matches a specific file. /var/www/broken.php ; A prefix that matches all files starting with x. /var/www/x ; A wildcard match. /var/www/*-broken.php 一行为一条规则,支持通配符,注释以分号开头 |
opcache.max_file_size | "0" | PHP_INI_SYSTEM | 被cache的文件的最大size,单位bytes。0表示不限 |
opcache.consistency_checks | "0" | PHP_INI_ALL | 如果置为N,N非零,则opcache会每N个请求核实一下cache的检验和。 这会损害性能,应该只在debug时使用 |
opcache.force_restart_timeout | "180" | PHP_INI_SYSTEM | 如果opcache处于非active状态,当N秒后opcache将自动重启 |
opcache.error_log | "" | PHP_INI_SYSTEM | opcache自身的errorlog文件路径,为空时则使用stderr |
opcache.log_verbosity_level | "1" | PHP_INI_SYSTEM | 日志记录level,默认只有fatal error和error |
opcache.preferred_memory_model | "" | PHP_INI_SYSTEM | opcache首选使用的内存模型,为空时会选择最适当的模型。 常用的有,mmap shm posix 和win32 |
opcache.protect_memory | "0" | PHP_INI_SYSTEM | 运行php脚本时保护共享内存防止意外的写入。 只对debug时有用。 |