来源:不言 发布时间:2018-11-24 09:31:43 阅读量:729
本篇文章给大家带来的内容是关于php中Opcache是什么?Opcache原理和使用的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
一、个人实践发现opcache
最近为了应对双十一期间高流量的冲击,小编通过压力测试去查找服务器性能瓶颈,发现100并发时,QPS
并不是很高,但CPU和内存消耗特别高,尤其是CPU消耗都100%了,而我们的容器和服务器配置都差不多升级到顶级了,这不是如此好的服务器该发挥的效果,于是小编进行了一次全面排查:
1、查看接口中数据库查询部分,该部分做了缓存,且redis的消耗并不是很高,排除数据库和缓存的影响性能因素;
2、查看有没有其他外部调用影响性能,发现这部分获取数据仅仅是通过数据库和缓存,因此排除;
3、查看接口程序代码中有没有复杂的逻辑计算,发现该部分处理的数据处理完了就直接缓存起来了,一段时间内数据来源都是redis缓存,因此排除
4、既然已上可能造成接口瓶颈的因此都排除了,那么最有可能的是现在使用的laravel5.0框架造成接口性能如此低下,然后通过框架文档、源码及网上资料等发现laravel框架在运行时会加载大量框架文件,然后对这些文件进行编译造成服务器CPU消耗特别高。通过这个方向,小编发现了PHP一个不错的缓存PHP编译文件的扩展opcache。
二、opcache的原理
1、Opcache是什么?
Opcache是一种通过将解析的PHP脚本预编译的字节码(Operate Code)存放在共享内存中来避免每次加载和解析PHP脚本的开销,解析器可以直接从共享内存读取已经缓存的字节码(Operate Code),从而大大提高PHP的执行效率。
2、什么是Operate Code?
当解释器完成对脚本代码的分析后,便将它们生成可以直接运行的中间代码,也称为操作码(Operate Code,opcode)。Opcode cache的目地是避免重复编译,减少CPU和内存开销。如果动态内容的性能瓶颈不在于CPU和内存,而在于I/O操作,比如数据库查询带来的磁盘I/O开销,那么opcode cache的性能提升是非常有限的。但是既然opcode cache能带来CPU和内存开销的降低,这总归是好事。现代操作码缓存器(Optimizer+,APC2.0+,其他)使用共享内存进行存储,并且可以直接从中执行文件,而不用在执行前“反序列化”代码。这将带来显着的性能加速,通常特别是高流量和高并发量时降低了整体服务器的内存消耗,而且很少有缺点。
3、为什么要使用Opcode缓存?
这得从PHP代码的生命周期说起,请求PHP脚本时,会经过五个步骤,如下图所示:
Zend引擎必须从文件系统读取文件、扫描其词典和表达式、解析文件、创建要执行的计算机代码(称为Opcode),最后执行Opcode。每一次请求PHP脚本都会执行一遍以上步骤,如果PHP源代码没有变化,那么Opcode也不会变化,显然没有必要每次都重行生成Opcode,结合在Web中无所不在的缓存机制,我们可以把Opcode缓存下来,以后直接访问缓存的Opcode岂不是更快,启用Opcode缓存之后的流程图如下所示:
因此使用了Operate Code缓存之后,PHP代码会直接获取opcode后直接执行,中间的三个步骤会省略掉因此会大幅提高PHP代码执行效率
三、Opcache的安装和使用
1、安装
1 2 3 4 5 6 7 8 9 10 |
|
2、使用
1 2 3 |
|
3、配置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
|