您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

使用 Zend Opcache 加速 PHP (2)

2024/12/2 9:44:12发布20次查看
optimizer+ 是 zend 开发的闭源但可以免费使用的 php 优化加速组件,是第一个也是最快的 opcode 缓存工具。现在,zend 科技公司将 optimizer+ 在 php license 下开源成为 zend opcache。
zend opcache 通过 opcode 缓存和优化提供更快的 php 执行过程。它将预编译的脚本文件存储在共享内存中供以后使用,从而避免了从磁盘读取代码并进行编译的时间消耗。同时,它还应用了一些代码优化模式,使得代码执行更快。
1. 什么是 opcode 缓存?当解释器完成对脚本代码的分析后,便将它们生成可以直接运行的中间代码,也称为操作码(operate code,opcode)。opcode cache 的目地是避免重复编译,减少 cpu 和内存开销。如果动态内容的性能瓶颈不在于 cpu 和内存,而在于 i/o 操作,比如数据库查询带来的磁盘 i/o 开销,那么 opcode cache 的性能提升是非常有限的。但是既然 opcode cache 能带来 cpu 和内存开销的降低,这总归是好事 本着环保的态度,也应该尽量减少消耗不是? :d
现代操作码缓存器(optimizer+,apc2.0+,其他)使用共享内存进行存储,并且可以直接从中执行文件,而不用在执行前“反序列化”代码。这将带来显着的性能加速,通常降低了整体服务器的内存消耗,而且很少有缺点。
2. optimizer+ 与 apc 的优缺点对比optimizer+ 于 2013年3月中旬改名为 opcache。
根据 php wiki 上的讨论,zend opcache 即将整合到 php 5.5 中。作为 apc 的竞争对手,新生的 zend opcache 很有可能取代 apc 的位置,虽然 optimizerplus 没有象 apc 那样的 user cache 功能。
optimizer+ 相对 apc 的优点性能。根据测试,zend optimizer+ 始终优于 apc。随代码差异,每秒钟处理的请求数高 5~20%。google doc 上记录的测试结果中,wordpress 2.1.1(不知道为什么不用个新版本的 wp 来测试),性能提高约 8%。理论上来说,对于 wp 3.5.1,性能应该也能得到大约 5~10% 的提升吧。对于运行 wordpress 的服务器而言,使用 optimizer+ 可以显著降低 cpu 使用率和提高页面加载速度(graphics here)。 支持新的 php 版本。zend 和 php 社区都会帮助 optimizer+ 能够支持最新版本的 php。 可靠性。optimizer+ 拥有可选的损坏检测能力,可以防止因数据损坏而导致的服务器崩溃。 更好的兼容性。php 社区打算让 optimizer+ 与社区支持的所有 php 版本相兼容。
apc 相对 optimizer+ 的优势apc 有数据缓存 api,而 optimizer+ 没有。 apc 能够回收旧的无效的脚本占用的内存。apc 有内存管理器,可以将那些不再使用的脚本关联的内存进行回收。而 optimizer+ 不同,它将这样的内存标记为“脏的”,但并不会回收它们。一旦“脏的”内存占用配置阈值的百分比达到一定值,optimizer+ 就将自己重新启动。这种行为在稳定性上既有优势也有劣势。
3. 使用 zend opcode现在已经可以使用 zend opcache 替代 apc 作为 php 优化加速工具了。目前的 zend opcode 兼容 php 5.2.*、5.3.*、5.4.* 和 php-5.5 开发版。不过,将来会取消对 php 5.2 的支持。
注意:zend opcache 与 eaccelerator 相冲突。要安装 zend opcache,可能需要先卸载 eaccelerator 如果你用了这个加速模块的话。
从源码安装并配置¶zend opcache 的源代码托管在 github 上,目前还是叫做 zendoptimizerplus。
安装步骤详见其 readme 文件。
注意:
最好在本地虚拟机里测试之后再部署到自己的服务器上; 安装前最好先删除 eacceleratro、xcache 或 apc 等组件。
顺便说一句,从源码编译安装时需要用到 php-devel。readme 中快速安装一节的开头就用到,
$php_dir/bin/phpize
如果不清楚 phpize 的路径,可以,
whereis phpize
readme 文件中也有相应的推荐优化设置。
从 epel 源安装并配置我不喜欢从源码编译安装程序,一个是水平有限,一个就是怕麻烦。下面介绍从 epel 安装源安装 zend opcache,以 centos 上的操作为例,基于我的 vps 的配置。
epel 社区已经提供了 zend opcache 的安装包,可以直接 yum 安装。当然,前提是已经配置使用了 epel 的安装源。如果没有,可以参考这里。
提醒一下,remi 安装源上的 php 已经是 5.4 版本了。鉴于有人测试说 wordpress 在 php 5.4 上的性能要优于在 php 5.3 上的性能(10% faster and lower ram consuming),顺便升级一下 php 也不是什么坏事。
操作步骤:
配置使用 epel 安装源。已有则跳过。 删除 eaccelerator、xcache、apc:
yum remove php-eaccelerator php-xcache php-apcu
没有使用则跳过。
对系统执行升级:
yum update
目的是根据 remi 安装源的状态升级当前的 php 等软件到 remi 支持的最新版本。此时,可以看到系统有类似下面的输出:
updating : php-common-5.4.14-1.el6.remi.i686 1/26warning : these php-* rpm are not official fedora / red hat build andoverrides the official ones. don't file bugs on fedora project nor red hat.use dedicated forums created as /etc/php.ini.rpmnew updating : mysql-libs-5.5.31-1.el6.remi.i686 2/26warning : this mysql rpm is not an official fedora / red hat build and itoverrides the official one. don't file bugs on fedora project nor red hat.use dedicated forums
表示我们现在要从 fedora / red hat 的版本迁移到 remi 版本了,所以不要去 fedora / red hat 寻求帮助了。呵呵,貌似出问题都是在网上找,还真是很少到官方论坛里提问。像我这样的入门级用户,也不会遇到那么深度的问题。
安装 zend opcache(pecl 版本):
yum install php-pecl-zendopcache
安装时产生的 opcache 的配置文件位于默认的 /etc/php.d 目录中:
opcache-default.blacklistopcache.ini
这个配置文件采用的基本就是 readme 中的推荐设置,只有几个地方需要修改。
vi /etc/php.d/opcache.ini
对照如下推荐配置修改并保存即可(可参考完整的 zend opcache 配置信息):
opcache.memory_consumption=128opcache.interned_strings_buffer=8opcache.max_accelerated_files=4000opcache.revalidate_freq=60opcache.fast_shutdown=1opcache.enable_cli=1
不需要修改 php.ini 配置,重起 apache 服务使之生效:
service httpd restart
查询一下看看是否正确启动了:
php -v
输出结果类似于:
php 5.4.14 (cli) (built: apr 11 2013 11:04:35)copyright (c) 1997-2013 the php groupzend engine v2.4.0, copyright (c) 1998-2013 zend technologies with zend opcache v7.0.1, copyright (c) 1999-2013, by zend technologies
4. 体会php 上有不少 opcode cache 组件,如 apc、eaccelerator、xcache 等。(参见 wikipedia 上的 php accelerators 列表。)看 php wiki 上的意思,这个新引入的 zend opcache 的性能应该是最好的。不管用哪个组件,总归是用一个才好。
对于小型的服务器,似乎这几个组件的性能差异并不太明显。我的想法是,既然用了,那就用个最好的吧。但是如果你正在使用别的 opcode cache,比如上面提到的这几个中的一个,从性能提升上讲,倒是没必要立刻就换。
对这个站,首页生成时间:仅使用 php 的时候,大约 0.9s;使用 eaccelerator 大约 0.63s;使用 zend opcache 后大约 0.55s。测试得非常简陋,多打开几次看看 wp super cache 提供的页面生成时间,估计一个平均数。
登录到系统里看了看 apache 进程的内存占用。之前一个进程不多大一会儿就能占用 40mb 以上的内存,现在基本上没有高于 40mb 的了。只是不知道是 php 5.4 的功劳呢,还是 zend opcache 的功劳。
不知道您觉得这个 zend opcache 的效果如何?如果您有兴趣,不妨留言写下您的测试结果。©
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product