摘要:什么是当解释器完成对脚本代码的分析后,便将它们生成可以直接运行的中间代码,也称为操作码,。的目地是避免重复编译,减少和内存开销。这将带来显着的性能加速,通常特别是高流量和高并发量时降低了整体服务器的内存消耗,而且很少有缺点。
一、个人实践发现opcache
最近为了应对双十一期间高流量的冲击,小编通过压力测试去查找服务器性能瓶颈,发现100并发时,QPS
并不是很高,但CPU和内存消耗特别高,尤其是CPU消耗都100%了,而我们的容器和服务器配置都差不多升级到顶级了,这不是如此好的服务器该发挥的效果,于是小编进行了一次全面排查:
查看接口中数据库查询部分,该部分做了缓存,且redis的消耗并不是很高,排除数据库和缓存的影响性能因素;
查看有没有其他外部调用影响性能,发现这部分获取数据仅仅是通过数据库和缓存,因此排除;
查看接口程序代码中有没有复杂的逻辑计算,发现该部分处理的数据处理完了就直接缓存起来了,一段时间内数据来源都是redis缓存,因此排除
既然已上可能造成接口瓶颈的因此都排除了,那么最有可能的是现在使用的laravel5.0框架造成接口性能如此低下,然后通过框架文档、源码及网上资料等发现laravel框架在运行时会加载大量框架文件,然后对这些文件进行编译造成服务器CPU消耗特别高。通过这个方向,小编发现了PHP一个不错的缓存PHP编译文件的扩展opcache。
二、opcache的原理
Opcache是什么?
Opcache是一种通过将解析的PHP脚本预编译的字节码(Operate Code)存放在共享内存中来避免每次加载和解析PHP脚本的开销,解析器可以直接从共享内存读取已经缓存的字节码(Operate Code),从而大大提高PHP的执行效率。
什么是Operate Code?
当解释器完成对脚本代码的分析后,便将它们生成可以直接运行的中间代码,也称为操作码(Operate Code,opcode)。Opcode cache的目地是避免重复编译,减少CPU和内存开销。如果动态内容的性能瓶颈不在于CPU和内存,而在于I/O操作,比如数据库查询带来的磁盘I/O开销,那么opcode cache的性能提升是非常有限的。但是既然opcode cache能带来CPU和内存开销的降低,这总归是好事。现代操作码缓存器(Optimizer+,APC2.0+,其他)使用共享内存进行存储,并且可以直接从中执行文件,而不用在执行前“反序列化”代码。这将带来显着的性能加速,通常特别是高流量和高并发量时降低了整体服务器的内存消耗,而且很少有缺点。
为什么要使用Opcode缓存?
这得从PHP代码的生命周期说起,请求PHP脚本时,会经过五个步骤,如下图所示:
Zend引擎必须从文件系统读取文件、扫描其词典和表达式、解析文件、创建要执行的计算机代码(称为Opcode),最后执行Opcode。每一次请求PHP脚本都会执行一遍以上步骤,如果PHP源代码没有变化,那么Opcode也不会变化,显然没有必要每次都重行生成Opcode,结合在Web中无所不在的缓存机制,我们可以把Opcode缓存下来,以后直接访问缓存的Opcode岂不是更快,启用Opcode缓存之后的流程图如下所示:
因此使用了Operate Code缓存之后,PHP代码会直接获取opcode后直接执行,中间的三个步骤会省略掉因此会大幅提高PHP代码执行效率三、Opcache的安装和使用
安装
当你的PHP版本低于7.0时,你可以去http://pecl.php.net/package/ZendOpcache 根据自己的PHP版 本下载相应的opcache版本。比如PHP5.5:http://pecl.php.net/get/zendopcache-7.0.5.tgz tar -zxvf zendopcache-7.0.5.tgz cd zendopcache-7.0.5 phpize ./configure --with-php-config=/usr/local/php/bin/php-config make make install 这是会在php的扩展文件夹内生成opcache.so PHP7.0之后自带opcache.so无需安装
使用
在php.ini加入zend_extension=opcache.so; 注意:这里是zend_extension不是extension,关于zend_extension和extension的区别可以去查阅 相关资料
配置
关于opcache的详细参数配置小编没怎么研究,针对比较核心的参数如下: opcache扩展位置 zend_extension=opcache.so 启用opcache opcache.enable=1 使用共享内存大小 opcache.memory_consumption=200 字符串缓存大小 opcache.interned_strings_buffer=8 最大缓存文件数量 opcache.max_accelerated_files=8000 出现异常,立即释放全部内存 opcache.fast_shutdown=1 最大允许占用内存百分比,超过此限制会重启进程 opcache.max_wasted_percentage=20 如果置为1,则将当前路径加入到文件key中,以避免可能产生的同文件名的文件key冲突 opcache.use_cwd=1 文件检测周期 revalidate_freq=3600 启用文件缓存时间戳 opcache.validate_timestamps=1
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/29688.html
摘要:大家知道目前的缓存插件一般有三个,但未来它们可能都会消失,因为已经集成,功能和前三者相似但又有少许不同,缓存速度据说比它们更快。下面是在本人虚拟机的环境下安装过程,记录一下。之后修改添加如下内容最后重启即可。 大家知道目前PHP的缓存插件一般有三个:APC、eAccelerator、XCache,但未来它们可能都会消失,因为PHP 5.5已经集成Zend Opcache,功能和前三者相...
摘要:如需要支持热启动,请自行谷歌,大概原理就是用监控文件变更,如果更新了重启如果正式环境中还可以自己写个部署脚本,后重启服务等,方法很多不一一列举。 1 Laravel的速度瓶颈在哪? 1.1 已有的一些优化方法 1.1.1 laravel官方提供了一些优化laravel的优化方法 php artisan optimize php artisan config:cache php arti...
摘要:来自博客整理于面试别人或被别人面试的一些题目持续更新答案网上基本都有,不一一列举。例有个人去游玩,需要买水,商店活动买瓶赠送一瓶。请问题目至少需要买多少瓶饮料才可以人手一瓶前端方面前端性能团队总结的条黄金定律说出几条 来自 AT博客整理于面试别人或被别人面试的一些题目(持续更新),答案网上基本都有,不一一列举。希望能帮到需要换工作的你。 数据库 mysql 索引的理解 mysql b...
摘要:来自博客整理于面试别人或被别人面试的一些题目持续更新答案网上基本都有,不一一列举。例有个人去游玩,需要买水,商店活动买瓶赠送一瓶。请问题目至少需要买多少瓶饮料才可以人手一瓶前端方面前端性能团队总结的条黄金定律说出几条 来自 AT博客整理于面试别人或被别人面试的一些题目(持续更新),答案网上基本都有,不一一列举。希望能帮到需要换工作的你。 数据库 mysql 索引的理解 mysql b...
阅读 3612·2021-11-23 09:51
阅读 1486·2021-11-04 16:08
阅读 3556·2021-09-02 09:54
阅读 3622·2019-08-30 15:55
阅读 2603·2019-08-30 15:54
阅读 963·2019-08-29 16:30
阅读 2051·2019-08-29 16:15
阅读 2323·2019-08-29 14:05