PHP优化加速之Opcache使用总结(转载)

转自 http://blog.csdn.net/why_2012_gogo/article/details/51134674

PHP优化加速之Opcache使用总结:

Opcache是一种通过将解析的PHP脚本预编译的字节码存放在共享内存中来避免每次加载和解析PHP脚本的开销,解析器可以直接从共享内存读取已经缓存的字节码,从而大大提高PHP的执行效率。PS: 需要区别于Xcache机制,后续总结中会介绍其使用。

·     如何安装

·     如何配置

·     如何使用

·     显示分析

·     注意事项

一、如何安装

在PHP 5.5.0及后续版本中,PHP已经将Opcache功能以拓展库形式内嵌在发布版本中了,默认未开启Opcache加速,需要开发人员在php.ini中添加或解注释Opcache相关配置即可。对于之前的老版本,可以将Opcache作为PECL拓展库进行安装和配置,可以参考PHP拓展安装及配置:

http://blog.csdn.net/why_2012_gogo/article/details/51120645

NOTE:

如果你使用 --disable-all 参数 禁用了默认扩展的构建, 那么必须使用--enable-opcache 选项来开启 Opcache。

二、如何配置

php.ini:

[opcache]

; 启动操作码缓存

opcache.enable=1

; 针对支持CLI版本PHP启动操作码缓存 一般被用来测试和调试

opcache.enable_cli=1

; 共享内存大小,单位为MB

opcache.memory_consumption=128

; 存储临时字符串缓存大小,单位为MB,PHP5.3.0以前会忽略此项配置

opcache.interned_strings_buffer=8

; 缓存文件数最大限制,命中率不到100%,可以试着提高这个值

opcache.max_accelerated_files=4000

; 一定时间内检查文件的修改时间, 这里设置检查的时间周期, 默认为 2, 单位为秒

opcache.revalidate_freq=60

; 开启快速停止续发事件,依赖于Zend引擎的内存管理模块,一次释放全部请求变量的内存,而不是依次释放内存块

opcache.fast_shutdown=1

;启用检查 PHP 脚本存在性和可读性的功能,无论文件是否已经被缓存,都会检查操作码缓存,可以提升性能。 但是如果禁用了 opcache.validate_timestamps选项, 可能存在返回过时数据的风险。

opcache.enable_file_override=1

; 拓展库so文件关联加载

zend_extension=/usr/local/lib/php/extensions/no-debug-non-zts-20131226/opcache.so

NOTE:

上面列出的配置项是常用且重要的配置项,实际不止上面这些配置项。

三、如何使用

实际上,对于Opcache的使用,主要体现在其提供的几个函数:

1、opcache_get_configuration;

形式:array opcache_get_configuration(void);

获取设置的缓存配置信息,以数组形式返回配置信息、黑名单及版本号。

2、opcache_get_status;

形式:array opcache_get_status(void);

获取设置的缓存状态信息。

3、opcache_invalidate;

形式:boolean opcache_invalidate (string);

该函数的作用是使得指定脚本的字节码缓存失效。如果force 没有设置或者传入的是 FALSE,那么只有当脚本的修改时间 比对应字节码的时间更新,脚本的缓存才会失效。

4、opcache_reset;

形式:boolean opcache_reset(void);

该函数将重置整个字节码缓存。在调用 opcache_reset() 之后,所有的脚本将会重新载入并且在下次被点击的时候重新解析。

5、opcache_compile_file;

形式:boolean opcache_compile_file (string);

无需运行,就可以编译并缓存脚本。

6、opcache_is_script_cached

形式:boolean opcache_is_script_cached (string);

判断某个脚本是否已经缓存到Opcache。

下面我编写一个PHP脚本,囊括上面的几个函数的封装,这样也方便日后对Opcache的维护和管理,具体如下:

<?php

/**

* 这个文件是对opcache优化器的几个

* 函数的封装,作为一个工具脚本使用

*/

if(!extension_loaded("ZendOpcache")) {

echo "You do nothave the Zend OPcache extension loaded , please open it up,then retry!";

}

/**

* 函数操作封装类

* 数组形式的结果,会转为json格式返回,不做显示上的处理

* 这里主要处理的是影响Opcache缓存状态的操作,对于查看

* Opcache各项指标的处理,可查看项目:opcache-status

*/

class OpcacheScriptModel{

private $_configuration;

private $_status;

function __construct() {

$this->_configuration =opcache_get_configuration();

$this->_status =opcache_get_status();

}

// 获取配置信息

public function getConfigDatas(){

echo json_encode($this->_configuration);

}

// 获取状态信息

public function getStatusDatas(){

echo json_encode($this->_status);

}

// 指定某脚本文件字节码缓存失效

public function invalidate($script){

return opcache_invalidate($script);

}

// 重置或清除整个字节码缓存数据

public function reset() {

return opcache_reset();

}

// 无需运行,就可以编译并缓存脚本

public function compile($file){

return opcache_compile_file($file);

}

// 判断某个脚本是否已经缓存到Opcache

public function isCached($script){

return opcache_is_script_cached($script);

}

}

// 获得对象

function getOpcacheDataModel(){

// 初始化对象

$dataModel = NULL;

if(NULL ==$dataModel) {

$dataModel = new OpcacheScriptModel();

}

return $dataModel;

}

?>

上面的脚本工具比较简单,一般可放在项目中或是单独作为工具使用,需要时去解析编译即可,其实下面的显示分析开源项目,也是使用上面的API函数,只不过其将获得数据以图形化形式展示出来,这样更加直观,请继续往下看。

四、显示分析

我们知道PHP脚本的执行机制是,解析器解析PHP脚本文件,并将其解析为字节码数据,而Opcache优化器的作用就是缓存被解析的字节码数据,做到直接从缓存中读取而不需要每次都重复PHP脚本的加载和解析工作,所以对于Opcache的使用,我们一般只需要做两件事儿:

1、使用Opcache优化器,加快PHP程序的执行速度;

2、通过Opcache各项指标参数,实时了解当前PHP程序的性能状态;

那么,我们如何去查看和分析当前的Opcache加速效果那?答案是可以使用下Github上开源的项目:https://github.com/rlerdorf/opcache-status

将下载下来的项目放入到当前的Web服务器根目录下,直接访问即可,先看效果:

从上面的截图及项目文件看出,该Opcache工具是一个简化的GUI版本,使用它可以清楚了解和分析下面的内容:

1、缓存使用情况、剩余情况及内存浪费情况及比例;

2、缓存的keys、剩余的keys数;

3、缓存命中数以及未命中数;

4、缓存配置、状态以及缓存捕获脚本;

5、缓存的脚本文件,以视图形式划分直观显示;

好了,Opcache的可视化就说到这里,下面看下几项注意点。

五、注意事项

1、不建议Xcache和Opcache同时启用PHP优化;

因为PHP 5.5.0及后续版本已经内嵌对Opcache的支持,所以PHP意识到其重要性,相对于Xcache等第三方的PHP优化器来说,使用Opcache会是更好的选择。另外,两者同时存在的话,会使Opcache的缓存命中数大大降低,而且增加不必要的开销。

2、不建议在开发过程中开启Opcache

原因很明显,开启了Opcache之后,开发人员修改的内容不会立即显示和生效,因为受到opcache.revalidate_freq=60的影响,所以建议在开发并测试之后,测试性能时再行打开测试,当然,生产环境一直都要开着Opcache了哦。

3、不建议将Opcache指标设置太大

Opcache各项指标配置大小或是否开启,需要结合项目实际情况需求及Opcache官方建议的配置,项目的实际情况分析,可结合上面第四部分的可视化缓存信息分析调整。

4、不建议长期使用老版本的Opcache

建议及时关注Opcache官网动态,实时了解其的bugs修复,功能优化及新增功能,以便更好的将其应用在自己的项目中。

5、不建议在生产环境中,将上面介绍的开源项目放入Web服务根目录

原因很简单,因为这个开源项目并未做访问的限制和安全处理,也就是说凡是可以访问外网的用户,只要知道了访问地址就可以直接访问,所以不安全。一般下,这个开源工具只是帮助可视化分析PHP的性能,通常在开发调试阶段使用。如果就是想在生产环境开启使用,那么就必须做好安全限制工作。

好了,到这里已经总结并介绍完了对于Opcache的使用,如需进一步优化底层,可以参看和修改源代码,不过一般情况下不需要哦!

原文地址:https://www.cnblogs.com/think-a-lot/p/8572681.html

时间: 2024-08-11 07:50:02

PHP优化加速之Opcache使用总结(转载)的相关文章

转 [PHP] - 性能加速 - 开启Opcache

原文地址:[PHP] - 性能加速 - 开启Opcache PHP7已经发布了, 作为PHP10年来最大的版本升级, 最大的性能升级, PHP7在多放的测试中都表现出很明显的性能提升  一.开启Opcache 在开启opcache之前,我们先介绍一下编译与解释 编译器是把源程序的每一条语句都编译成机器语言,并保存成二进制文件,这样运行时计算机可以直接以机器语言来运行此程序,速度很快; 而解释器则是只在执行程序时,才一条一条的解释成机器语言给计算机来执行,所以运行速度是不如编译后的程序运行的快的.

[PHP] - 性能加速 - 开启opcache

说明 PHP 5.5+版本以上的,可以使用PHP自带的opcache开启性能加速(默认是关闭的).对于PHP 5.5以下版本的,需要使用APC加速,这里不说明,可以自行上网搜索PHP APC加速的方法. PHP开启opcache方法 1.打开php.ini文件 2.找到:[opcache],设置为: [opcache] ; dll地址 zend_extension=php_opcache.dll ; 开关打开 opcache.enable=1 ; 开启CLI opcache.enable_cli

性能加速 - 开启opcache

说明 PHP 5.5+版本以上的,可以使用PHP自带的opcache开启性能加速(默认是关闭的).对于PHP 5.5以下版本的,需要使用APC加速,这里不说明,可以自行上网搜索PHP APC加速的方法. PHP开启opcache方法 1.打开php.ini文件 2.找到:[opcache],设置为: [opcache] ; dll地址 zend_extension=php_opcache.dll ; 开关打开 opcache.enable=1 ; 开启CLI opcache.enable_cli

php中的脚本加速扩展opcache

转自http://blog.jjonline.cn/linux/135.html 今儿在azure里装php5.5.4,发现原先php5.4.php5.3中的zend guard laoder以及php5.2中的Zend Optimizer均不能再用,一直很喜欢用的eaccelerator也悲剧了,编译的时候直接提示错误. 没办法,翻看php5.5.4的安装目录,发现php的安装目录下的扩展库目录有个opcached.so:咦,这个文件是搞毛线的?看名字带cached,难道是个缓存系统?goog

Firefox火狐浏览器优化加速about:config配置

如果你是个爱折腾的火狐迷,进阶about:config火狐浏览器高级配置命令就不得不学啦,用了chrome后会不会小小抱怨火狐上网速度慢了?不过相信你还是不会嫌弃火狐的.本文主要介绍一些修改about:config高级配置的参数来优化加速火狐,实用易学,解释详细,通俗易懂,童叟无欺! 在火狐浏览器地址栏键入about:config回车,打开火狐高级设置,在搜索框中输入下列命令. 1.network.prefetch-nextfalse = false 火狐预加载功能,当载入一个网页后,火狐会预加

[转载]MATLAB代码分析优化加速

Profile(分析)在加速你的matlab程序之前,你需要知道你的代码哪一部分运行最慢.matlab提供个简单的机制,让你能够知道你的代码的某一部分运行所占用CPU时间.通过在代码段开始添加tic,及在结束添加toc:matlab就能计算出这一代码段的运行时间.Tic和toc方法存在两个问题:(1)显示的时间是运行时间“wall clock”.这个时间受你在运行你的代码时,你的计算机是否同时运行其它别的程序.(2)你需要不断地压缩计时范围来查找你代码运行最慢的位置.一个最好的方法是利用matl

MySQL优化之COUNT(*)效率(部分转载与个人亲测)

说到MySQL的COUNT(*)的效率,发现越说越说不清楚,干脆写下来,分享给大家. COUNT(*)与COUNT(COL)网上搜索了下,发现各种说法都有:比如认为COUNT(COL)比COUNT(*)快的:认为COUNT(*)比COUNT(COL)快的:还有朋友很搞笑的说到这个其实是看人品的. 在不加WHERE限制条件的情况下,COUNT(*)与COUNT(COL)基本可以认为是等价的:但是在有WHERE限制条件的情况下,COUNT(*)会比COUNT(COL)快非常多: 具体的数据参考如下:

50种方法优化SQL Server数据库查询(转载)

原文地址:http://www.cnblogs.com/zhycyq/articles/2636748.html 查询速度慢的原因很多,常见如下几种: 1.没有索引或者没有用到索引(这是查询慢最常见的问题,是程序设计的缺陷) 2.I/O吞吐量小,形成了瓶颈效应. 3.没有创建计算列导致查询不优化. 4.内存不足 5.网络速度慢 6.查询出的数据量过大(可以采用多次查询,其他的方法降低数据量) 7.锁或者死锁(这也是查询慢最常见的问题,是程序设计的缺陷) 8.sp_lock,sp_who,活动的用

SQL Server数据库性能优化之SQL语句篇(转载)

SQL Server数据库性能优化之SQL语句篇 原文地址:http://www.blogjava.net/allen-zhe/archive/2010/07/23/326927.html 期项目需要,做了一段时间的SQL Server性能优化,遇到了一些问题,也积累了一些经验,现总结一下,与君共享.SQL Server性能优化涉及到许多方面,如良好的系统和数据库设计,优质的SQL编写,合适的数据表索引设计,甚至各种硬件因素:网络性能.服务器的性能.操作系统的性能,甚至网卡.交换机等.这篇文章主