PHP工作原理

首先,我们先了解下解释型语言PHP的工作原理,这有利于我们了解PHP Opcache。

对于PHP,我们常用的是cli模式和php-fpm模式。下面我们拿cli模式来描述下php执行脚本的运行过程:

  1. php初始化执行,启动zend引擎,加载已注册的扩展模块
  2. 读取脚本文件,zend引擎对脚本进行词法分析、语法分析、生成语法生成树
  3. zend引擎编译语法树,生成opcode中间代码
  4. zend引擎执行opcode,返回执行结果

对于cli模式来说,每次执行php脚本,都会将以上流程完整执行一遍。

而对于php-fpm模式来说,php初始化环节(步骤1)会在php-fpm启动时执行,而之后的步骤则是会在每次请求执行时重复执行(php-fpm+nginx的工作原理,不了解的同学可以翻看一下之前的文章nginx+php执行请求的工作原理)。

对于大流量高并发项目来说,每次执行脚本或者请求时都需要重新编译固定不变的脚本文件,生成固定的opcode,确实有些浪费资源了,所以opcache应运而生。

PHP Opcache

Opcache,简单来说,是php应对每次都需要重复编译的脚本文件而开发的组件,可以节省上文所说的解析脚本文件的开销。

Opcache缓存的内容

目前,Opcache缓存的内容包括:

  • Opcode
  • Interned String(可以理解为php请求生命周期中不需要释放的String,包括:变量名、类名、方法名、字符串、注释等)

Opcache工作原理

Opcache工作原理其实是使用了共享内存机制,将需要缓存的内容放入到共享内存中,供其他进程使用。

因为Opcache在创建缓存的过程中不会阻止其他进程读取,所以在使用Opcache时要注意两点,不然会大量消耗资源:

  • 不要给Opcache设置过期时间
  • 不要在流量高峰期发布代码

切记!

Opcache配置

说了这么多,下面我们来看下Opcache如何配置呢?

Opcache配置是放置在php.ini文件中的(没有安装该扩展的同学可以自行百度安装该扩展),我们接下来主要讲解一些重要的配置,以来提升PHP整体性能。

//添加Opcache扩展
zend_extension=opcache.so
//开启Opcache
opcache.enable=1
//cli环境下启用Opcache
opcache.enable_cli=1
//浪费内存的上限,以百分比计,如果达到该上限,Opcache则会清空并重新生成缓存。默认5%
opcache.max_wasted_percentage=5
//配置共享内存存储大小,单位MB
opcache.memory_consumption=128
//用来存储临时字符串的内存大小,单位MB。这个配置就是上面说到的Opcache缓存的interned_string,它会在第一次使用到interned_string时缓存到共享内存中,供其他进程后续使用
opcache.interned_strings_buffer=8
//用于控制共享内存最多可以缓存多少个文件,该值最小范围是200,在php5.5.6版本之后,最大值是1000000
opcache.max_accelerated_files=4000
//设置缓存的过期时间,为0的话则每次都要检查
opcache.revalidate_freq=60
//如果启用,OPcache会在opcache.revalidate_freq设置的秒数去检测文件的时间戳(timestamp)检查脚本是否更新。如果这个选项被禁用(设置为0),opcache.revalidate_freq会被忽略,PHP文件永远不会被检查。这意味着如果你修改了你的代码,然后你把它更新到服务器上,再在浏览器上请求更新的代码对应的功能,你会看不到更新的效果
opcache.validate_timestamps=0 //所以像我上面说的,在大流量高并发场景下,该项不要启用,切记
//启用后,可以将依赖Zend引擎的内存管理模块一次释放全部请求变量的内存,而不是依次释放每一个已分配的内存块。
opcache.fast_shutdown=1
//启用文件缓存(设置缓存路径),这样Opcache就可以将Opcode缓存到文件中,实现跨php生命周期缓存
opcache.file_cache=/tmp

  

 

版权声明:本文为百事可口原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/jimz/p/16963061.html