PHP--opcode 脚本缓存
2016-10-17 22:33
197 查看
C/C++将动态内容编译成二进制可执行文件(目标代码),由操作系统进程直接装载运行,速度非常快。但PHP等语言不是编译型,而是解释型,它们不直接由操作系统来运行,而是由专门的解释器来运行,而解释器则由操作系统运行。
PHP由一个二进执行文件,如:/usr/local/php/bin/php 来执行。在执行过程中,解释器对代码进行分析,然后进行运算。比如,我们在命令行中输入:
/usr/bin/php -r 'echo 333;'
会输出结果:333
PHP解释器先分析我们输入的 echo 333;然后将它们生成可以直接运行的中间代码,也称操作码:Operate Code,opcode。
要查看PHP的opcode要先安装 parsekit 扩展。
安装 parsekit 扩展查看opcode
wget http://pecl.php.net/get/parsekit-1.3.0.tgz
[root@localhost software]# tar -zxvf parsekit-1.3.0.tgz
[root@localhost software]# cd parsekit-1.3.0
[root@localhost parsekit-1.3.0]# /usr/local/php/bin/phpize
Configuring for:
PHP Api Version: 20041225
Zend Module Api No: 20060613
Zend Extension Api No: 220060519
[root@localhost parsekit-1.3.0]# ./configure -with-php-config=/usr/local/php/bin/php-config
[root@localhost parsekit-1.3.0]# make
[root@localhost parsekit-1.3.0]# make install
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/
vim /usr/local/php/etc/php.ini
加入 extension=parsekit.so
配置文件的地址可以在 phpinfo 中查看。so 的地址即上面 make install 的目录下。
在命令行中输入:
/usr/local/php/bin/php -r "var_dump(parsekit_compile_string('print 1+1;'));"
结果如下图:
后面还有很长。但可以看到,结果是以数组形式返回的。而且红框中标识的就是一些关键语法,如:ZEND_ADD,ZEND_PRINT 以及没有贴上图片的ZEND_FREE, ZEND_RETURE 通过单词可以猜出它们分别意味着什么。
1.如果要查看单句php的opcode
# /usr/local/php/bin/php -r "var_dump(parsekit_compile_string('print 1+1;'));"
参考 http://www.php.net/manual/zh/function.parsekit-compile-string.php
2.如果要查看网站下某个php文件的opcode
# /usr/local/php/bin/php -r "var_dump(parsekit_compile_file('/var/www/tb.php'));"
参考 http://www.php.net/manual/zh/function.parsekit-compile-file.php
而上面的过程,我们可以看到。每条PHP语句都会被解释器解释成 opcode 然后在需要的时候执行。然而,解释PHP语句这一个过程也是会有消耗的,我们能否节省这一部分的消耗呢?就象我们大脑,第一次被别人问到 12 * 12 等到多少时,会计算一下,得出 144。如果被多次问,则会毫不犹豫的说 144。但缓存 opcode 在程序中是无法做到的,这要解释器这一层自己去做。PHP有诸如APC,eAccelerator,XCache 等可以帮我们实现。
wget http://xcache.lighttpd.net/pub/Releases/1.3.2/xcache-1.3.2.tar.gz
tar -zxvf xcache-1.3.2.tar.gz
cd xcache-1.3.2
phpize
./configure --enable-xcache
make
make install
打开php.ini文件,增加如下代码:
[xcache-common]
; change me - 64 bit php => /usr/lib64/php/modules/xcache.so
; 32 bit php => /usr/lib/php/modules/xcache.so
zend_extension = /usr/lib64/php/modules/xcache.so
[xcache.admin]
xcache.admin.auth = On
xcache.admin.user = "mOo"
; xcache.admin.pass = md5($your_password)
xcache.admin.pass = ""
[xcache]
xcache.shm_scheme = "mmap"
xcache.size = 32M
xcache.count = 1
xcache.slots = 8K
xcache.ttl = 3600
xcache.gc_interval = 300
; Same as aboves but for variable cache
; If you don't know for sure that you need this, you probably don't
xcache.var_size = 0M
xcache.var_count = 1
xcache.var_slots = 8K
xcache.var_ttl = 0
xcache.var_maxttl = 0
xcache.var_gc_interval = 300
; N/A for /dev/zero
xcache.readonly_protection = Off
xcache.mmap_path = "/dev/zero"
xcache.cacher = On
xcache.stat = On
注意修改zend_extension = /usr/lib64/php/modules/xcache.so为正确的路径。
# wget http://bart.eaccelerator.net/source/0.9.6/eaccelerator-0.9.6.tar.bz2
# tar -jxvf eaccelerator-0.9.6.tar.bz2
# cd eaccelerator-0.9.6
# /usr/local/php/bin/phpize
# ./configure --enable-eaccelerator=shared --with-php-config=/usr/local/php/bin/php-config
# make && make install
eaccelerator.shm_size="32"
eAccelerator 可以使用的共享内存的数量 (以兆为单位) . “0″ 是指操作系统的默认值. 默认值是 “0″.可根据服务器的实际情况来调整,16,32,64,128都是可以的。
eaccelerator.cache_dir="/home/php/tmp"
这个目录是给磁盘缓存使用. eAccelerator 在这里储存预先编译好的代码, 进程数据, 内容以及用户的自定义内容. 同样的数据也能被储存在共享内存中 (这样可以提高访问速度). 默认的设置是 “/tmp/eaccelerator”.
eaccelerator.enable="1"
开启或关闭 eAccelerator。”1″ 为开启,”0″ 为关闭。默认值为 “1″。
eaccelerator.optimizer="1"
启或关闭内部优化器,可以提升代码执行速度。”1″ 为开启,”0″ 为关闭。默认值为 “1″。
eaccelerator.check_mtime=”1″
打开或者关闭 PHP 的文件修改检查. “1″ 是指打开, “0″ 是指关闭. 如果您在修改以后重新编译 PHP 的文件,那么您应当设置为 “1″. 默认值是 “1″.
eaccelerator.debug="0"
开启或关闭调试日志记录。”1″ 为开启,”0″ 为关闭。默认值为 “0″。会将缓存命中得记录写入日志。
eaccelerator.filter=""
判断哪些 PHP 文件必须缓存。您可以指定缓存和不缓存的文件类型(如 “*.php *.phtml”等)
如果参数以 “!” 开头,则匹配这些参数的文件被忽略缓存。默认值为 “”,即,所有 PHP 文件都将被缓存。
eaccelerator.shm_max="0"
当使用 ” eaccelerator_put() ” 函数时禁止其向共享内存中存储过大的文件。该参数指定允许存储的最大值,单位:字节 (10240, 10K, 1M)。”0″ 为不限制。默认值为 “0″。
eaccelerator.shm_ttl="0"
当 eAccelerator 获取新脚本的共享内存大小失败时,它将从共享内存中删除所有在最后 “shm_ttl” 秒内没有存取的脚本缓存。默认值为 “0″,即:不从共享内春中删除任何缓存文件。
eaccelerator.shm_prune_period="0"
当 eAccelerator 获取新脚本的共享内存大小失败时,他将试图从共享内存中删除早于”shm_prune_period” 秒的缓存脚本。默认值为 “0″,即:不从共享内春中删除任何缓存文件。
eaccelerator.shm_only="0"
允许或禁止将已编译脚本缓存在磁盘上。该选项对 session 数据和内容缓存无效。默认值为 “0″,即:使用磁盘和共享内存进行缓存。
eaccelerator.compress="1"
允许或禁止压缩内容缓存。默认值为 “1″,即:允许压缩。
eaccelerator.compress_level="9"
指定内容缓存的压缩等级。默认值为 “9″,为最高等级。
eaccelerator.keys = "disk_only"
eaccelerator.session = "disk_only"
eaccelerator.content = "disk_only"
设置内容缓存的存放的地方,可以设置为:
shm_and_disk 在共享缓存和硬盘(默认值)
shm 默认存在共享内存,如果共享内存已满或大小超过 “eaccelerator.shm_max” 的值,就存到硬盘
shm_only 只存放在共享内存
disk_only 只存放在硬盘
none 不缓存数据
eaccelerator.allowed_admin_path = "/var/www/html/21andy.com/eaccelerator"
这是控制面板的地址
安装包里有个control.php,你把它复制到网站的任意目录,可以用它查看和管理,这个必须指定,否则查看缓存内容的时候会出错
最后,来看一下我的 eAccelerator 设置
; eaccelerator
[eaccelerator]
zend_extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/eaccelerator.so"
eaccelerator.shm_size="128"
eaccelerator.cache_dir="/tmp/eaccelerator"
eaccelerator.enable="1"
eaccelerator.optimizer="1"
eaccelerator.check_mtime="1"
eaccelerator.debug="0"
eaccelerator.filter=""
eaccelerator.shm_max="0"
eaccelerator.shm_ttl="3600"
eaccelerator.shm_prune_period="3600"
eaccelerator.shm_only="0"
eaccelerator.compress="1"
eaccelerator.compress_level="9"
eaccelerator.keys = "disk_only"
eaccelerator.sessions = "disk_only"
eaccelerator.content = "disk_only"
eaccelerator.allowed_admin_path = "/var/www/html/21andy.com/eaccelerator"
下载:
wget http://pecl.php.net/get/APC-3.1.9.tgz
解压:
tar -xf APC-3.1.9.tgz
cd APC-3.1.9
/usr/local/php/bin/phpize
./configure -enable-apc -enable-apc-mmap -with-php-config=/usr/local/php/bin/php-config
make && make install
然后更改 php.ini
vi /usr/local/php/etc/php.ini
在最后加上:
extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/apc.so"
把 apc.so 配置上去.
如果不知道本机 apc.so 在哪里,可以查找一下:
find / -type f -name apc.so
如果找不到,那说明前面的编译没成功。
再在 php.ini 里添加 apc 配置:
; APC Module
extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/apc.so"
apc.enabled = "1"
apc.filters = "/cache/"
apc.max_file_size = "2M"
apc.write_lock = "1"
apc.slam_defense = "0"
apc.shm_segments = "1"
apc.shm_size = "128M"
apc.ttl = "0"
apc.user_ttl = "0"
apc.gc_ttl = "3600"
apc.stat = "1"
apc.stat_ctime = "0"
apc.include_once_override = "0"
apc.num_files_hint = "8000"
apc.stat
1 为1或者 On 时,修改文件,会自动更新缓存,但是性能会略受到些影响,如果为0或者Off时,将无法自动更新缓存,修改好以后,必须重启web
server,但是性能会相对高一些
apc.enabled 可以被设成
0 来禁用 APC。这主要是有用的,当 APC 被静态编译入 PHP 时,因为没有其它方法来禁用它(当编译为 DSO 的时候,可以将 php.ini 中的 extension 行注释掉)。
apc.shm_segments 整型
对编译缓存分配共享内存块的数量。如果APC用光了共享内存,而且你已经设置 apc.shm_size为系统允许的最大值的情况下,你可以试着去提高这个参数的值。
apc.shm_size 整型
每个共享内存块的大小是以MB为单位的。在默认情况下,一些系统(包括大多数BSD变种系统)的共享内存块的大小限制的很低。
apc.num_files_hint 整型
对在你的Web服务器上被包含和请求的不同的源文件的数量的提示。如果你无法确定,设置为0或者省略;这个设置主要可能用于有成千的源文件的站点。
apc.ttl 整型
当一个缓存条目在缓存区的位置被另一个条目需要时,我们需要考虑的是这个缓存条目在缓存区的位置被允许空闲的秒数。将这个参数设置为0意味着你的缓存可能充满不新鲜的条目,同时导致新的条目无法被缓存。
apc.gc_ttl 整型
缓存条目在垃圾收集列表中存活的秒数。这个值提供了出错保护在执行一个缓存源文件,而同时服务器进程死了的事件中。如果那个源文件被修改,内存分配给旧版本的缓存条目将不会被回收,直到这个参数设定的TTL值到的时候。设置为0就是禁止这个特性。
apc.cache_by_default 布尔型
默认为On,但可以被设置为Off并和以加号开头的apc.filters配合使用,文件仅仅在匹配过滤器时才被缓存。
apc.filters 字符串
一个以逗号分割的POSIX扩展正则表达式的列表。如果任何模式匹配源文件名,这个文件将不会被缓存。注意用来匹配的文件名是传递给 include/require 的文件名,而不是绝对路径。如果正则表达式的第一个字符是 + ,则这个表达式就意味着任何匹配表达式的文件将会被缓存,如果第一个字符是 - 则任何匹配都不会被缓存。 - 是默认值,所以可以被省略。
原文地址:http://blog.sina.com.cn/s/blog_5f54f0be010126vc.html
PHP由一个二进执行文件,如:/usr/local/php/bin/php 来执行。在执行过程中,解释器对代码进行分析,然后进行运算。比如,我们在命令行中输入:
/usr/bin/php -r 'echo 333;'
会输出结果:333
PHP解释器先分析我们输入的 echo 333;然后将它们生成可以直接运行的中间代码,也称操作码:Operate Code,opcode。
要查看PHP的opcode要先安装 parsekit 扩展。
安装 parsekit 扩展查看opcode
wget http://pecl.php.net/get/parsekit-1.3.0.tgz
[root@localhost software]# tar -zxvf parsekit-1.3.0.tgz
[root@localhost software]# cd parsekit-1.3.0
[root@localhost parsekit-1.3.0]# /usr/local/php/bin/phpize
Configuring for:
PHP Api Version: 20041225
Zend Module Api No: 20060613
Zend Extension Api No: 220060519
[root@localhost parsekit-1.3.0]# ./configure -with-php-config=/usr/local/php/bin/php-config
[root@localhost parsekit-1.3.0]# make
[root@localhost parsekit-1.3.0]# make install
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/
vim /usr/local/php/etc/php.ini
加入 extension=parsekit.so
配置文件的地址可以在 phpinfo 中查看。so 的地址即上面 make install 的目录下。
在命令行中输入:
/usr/local/php/bin/php -r "var_dump(parsekit_compile_string('print 1+1;'));"
结果如下图:
后面还有很长。但可以看到,结果是以数组形式返回的。而且红框中标识的就是一些关键语法,如:ZEND_ADD,ZEND_PRINT 以及没有贴上图片的ZEND_FREE, ZEND_RETURE 通过单词可以猜出它们分别意味着什么。
1.如果要查看单句php的opcode
# /usr/local/php/bin/php -r "var_dump(parsekit_compile_string('print 1+1;'));"
参考 http://www.php.net/manual/zh/function.parsekit-compile-string.php
2.如果要查看网站下某个php文件的opcode
# /usr/local/php/bin/php -r "var_dump(parsekit_compile_file('/var/www/tb.php'));"
参考 http://www.php.net/manual/zh/function.parsekit-compile-file.php
而上面的过程,我们可以看到。每条PHP语句都会被解释器解释成 opcode 然后在需要的时候执行。然而,解释PHP语句这一个过程也是会有消耗的,我们能否节省这一部分的消耗呢?就象我们大脑,第一次被别人问到 12 * 12 等到多少时,会计算一下,得出 144。如果被多次问,则会毫不犹豫的说 144。但缓存 opcode 在程序中是无法做到的,这要解释器这一层自己去做。PHP有诸如APC,eAccelerator,XCache 等可以帮我们实现。
XCache相关
安装
wget http://xcache.lighttpd.net/pub/Releases/1.3.2/xcache-1.3.2.tar.gz tar -zxvf xcache-1.3.2.tar.gz
cd xcache-1.3.2
phpize
./configure --enable-xcache
make
make install
设置
打开php.ini文件,增加如下代码:[xcache-common]
; change me - 64 bit php => /usr/lib64/php/modules/xcache.so
; 32 bit php => /usr/lib/php/modules/xcache.so
zend_extension = /usr/lib64/php/modules/xcache.so
[xcache.admin]
xcache.admin.auth = On
xcache.admin.user = "mOo"
; xcache.admin.pass = md5($your_password)
xcache.admin.pass = ""
[xcache]
xcache.shm_scheme = "mmap"
xcache.size = 32M
xcache.count = 1
xcache.slots = 8K
xcache.ttl = 3600
xcache.gc_interval = 300
; Same as aboves but for variable cache
; If you don't know for sure that you need this, you probably don't
xcache.var_size = 0M
xcache.var_count = 1
xcache.var_slots = 8K
xcache.var_ttl = 0
xcache.var_maxttl = 0
xcache.var_gc_interval = 300
; N/A for /dev/zero
xcache.readonly_protection = Off
xcache.mmap_path = "/dev/zero"
xcache.cacher = On
xcache.stat = On
注意修改zend_extension = /usr/lib64/php/modules/xcache.so为正确的路径。
eAccelerator相关
安装
# wget http://bart.eaccelerator.net/source/0.9.6/eaccelerator-0.9.6.tar.bz2 # tar -jxvf eaccelerator-0.9.6.tar.bz2
# cd eaccelerator-0.9.6
# /usr/local/php/bin/phpize
# ./configure --enable-eaccelerator=shared --with-php-config=/usr/local/php/bin/php-config
# make && make install
设置
eaccelerator.shm_size="32"eAccelerator 可以使用的共享内存的数量 (以兆为单位) . “0″ 是指操作系统的默认值. 默认值是 “0″.可根据服务器的实际情况来调整,16,32,64,128都是可以的。
eaccelerator.cache_dir="/home/php/tmp"
这个目录是给磁盘缓存使用. eAccelerator 在这里储存预先编译好的代码, 进程数据, 内容以及用户的自定义内容. 同样的数据也能被储存在共享内存中 (这样可以提高访问速度). 默认的设置是 “/tmp/eaccelerator”.
eaccelerator.enable="1"
开启或关闭 eAccelerator。”1″ 为开启,”0″ 为关闭。默认值为 “1″。
eaccelerator.optimizer="1"
启或关闭内部优化器,可以提升代码执行速度。”1″ 为开启,”0″ 为关闭。默认值为 “1″。
eaccelerator.check_mtime=”1″
打开或者关闭 PHP 的文件修改检查. “1″ 是指打开, “0″ 是指关闭. 如果您在修改以后重新编译 PHP 的文件,那么您应当设置为 “1″. 默认值是 “1″.
eaccelerator.debug="0"
开启或关闭调试日志记录。”1″ 为开启,”0″ 为关闭。默认值为 “0″。会将缓存命中得记录写入日志。
eaccelerator.filter=""
判断哪些 PHP 文件必须缓存。您可以指定缓存和不缓存的文件类型(如 “*.php *.phtml”等)
如果参数以 “!” 开头,则匹配这些参数的文件被忽略缓存。默认值为 “”,即,所有 PHP 文件都将被缓存。
eaccelerator.shm_max="0"
当使用 ” eaccelerator_put() ” 函数时禁止其向共享内存中存储过大的文件。该参数指定允许存储的最大值,单位:字节 (10240, 10K, 1M)。”0″ 为不限制。默认值为 “0″。
eaccelerator.shm_ttl="0"
当 eAccelerator 获取新脚本的共享内存大小失败时,它将从共享内存中删除所有在最后 “shm_ttl” 秒内没有存取的脚本缓存。默认值为 “0″,即:不从共享内春中删除任何缓存文件。
eaccelerator.shm_prune_period="0"
当 eAccelerator 获取新脚本的共享内存大小失败时,他将试图从共享内存中删除早于”shm_prune_period” 秒的缓存脚本。默认值为 “0″,即:不从共享内春中删除任何缓存文件。
eaccelerator.shm_only="0"
允许或禁止将已编译脚本缓存在磁盘上。该选项对 session 数据和内容缓存无效。默认值为 “0″,即:使用磁盘和共享内存进行缓存。
eaccelerator.compress="1"
允许或禁止压缩内容缓存。默认值为 “1″,即:允许压缩。
eaccelerator.compress_level="9"
指定内容缓存的压缩等级。默认值为 “9″,为最高等级。
eaccelerator.keys = "disk_only"
eaccelerator.session = "disk_only"
eaccelerator.content = "disk_only"
设置内容缓存的存放的地方,可以设置为:
shm_and_disk 在共享缓存和硬盘(默认值)
shm 默认存在共享内存,如果共享内存已满或大小超过 “eaccelerator.shm_max” 的值,就存到硬盘
shm_only 只存放在共享内存
disk_only 只存放在硬盘
none 不缓存数据
eaccelerator.allowed_admin_path = "/var/www/html/21andy.com/eaccelerator"
这是控制面板的地址
安装包里有个control.php,你把它复制到网站的任意目录,可以用它查看和管理,这个必须指定,否则查看缓存内容的时候会出错
最后,来看一下我的 eAccelerator 设置
; eaccelerator
[eaccelerator]
zend_extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/eaccelerator.so"
eaccelerator.shm_size="128"
eaccelerator.cache_dir="/tmp/eaccelerator"
eaccelerator.enable="1"
eaccelerator.optimizer="1"
eaccelerator.check_mtime="1"
eaccelerator.debug="0"
eaccelerator.filter=""
eaccelerator.shm_max="0"
eaccelerator.shm_ttl="3600"
eaccelerator.shm_prune_period="3600"
eaccelerator.shm_only="0"
eaccelerator.compress="1"
eaccelerator.compress_level="9"
eaccelerator.keys = "disk_only"
eaccelerator.sessions = "disk_only"
eaccelerator.content = "disk_only"
eaccelerator.allowed_admin_path = "/var/www/html/21andy.com/eaccelerator"
APC 相关:
下载:wget http://pecl.php.net/get/APC-3.1.9.tgz
解压:
tar -xf APC-3.1.9.tgz
cd APC-3.1.9
/usr/local/php/bin/phpize
./configure -enable-apc -enable-apc-mmap -with-php-config=/usr/local/php/bin/php-config
make && make install
然后更改 php.ini
vi /usr/local/php/etc/php.ini
在最后加上:
extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/apc.so"
把 apc.so 配置上去.
如果不知道本机 apc.so 在哪里,可以查找一下:
find / -type f -name apc.so
如果找不到,那说明前面的编译没成功。
再在 php.ini 里添加 apc 配置:
; APC Module
extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20060613/apc.so"
apc.enabled = "1"
apc.filters = "/cache/"
apc.max_file_size = "2M"
apc.write_lock = "1"
apc.slam_defense = "0"
apc.shm_segments = "1"
apc.shm_size = "128M"
apc.ttl = "0"
apc.user_ttl = "0"
apc.gc_ttl = "3600"
apc.stat = "1"
apc.stat_ctime = "0"
apc.include_once_override = "0"
apc.num_files_hint = "8000"
apc.stat
1 为1或者 On 时,修改文件,会自动更新缓存,但是性能会略受到些影响,如果为0或者Off时,将无法自动更新缓存,修改好以后,必须重启web
server,但是性能会相对高一些
apc.enabled 可以被设成
0 来禁用 APC。这主要是有用的,当 APC 被静态编译入 PHP 时,因为没有其它方法来禁用它(当编译为 DSO 的时候,可以将 php.ini 中的 extension 行注释掉)。
apc.shm_segments 整型
对编译缓存分配共享内存块的数量。如果APC用光了共享内存,而且你已经设置 apc.shm_size为系统允许的最大值的情况下,你可以试着去提高这个参数的值。
apc.shm_size 整型
每个共享内存块的大小是以MB为单位的。在默认情况下,一些系统(包括大多数BSD变种系统)的共享内存块的大小限制的很低。
apc.num_files_hint 整型
对在你的Web服务器上被包含和请求的不同的源文件的数量的提示。如果你无法确定,设置为0或者省略;这个设置主要可能用于有成千的源文件的站点。
apc.ttl 整型
当一个缓存条目在缓存区的位置被另一个条目需要时,我们需要考虑的是这个缓存条目在缓存区的位置被允许空闲的秒数。将这个参数设置为0意味着你的缓存可能充满不新鲜的条目,同时导致新的条目无法被缓存。
apc.gc_ttl 整型
缓存条目在垃圾收集列表中存活的秒数。这个值提供了出错保护在执行一个缓存源文件,而同时服务器进程死了的事件中。如果那个源文件被修改,内存分配给旧版本的缓存条目将不会被回收,直到这个参数设定的TTL值到的时候。设置为0就是禁止这个特性。
apc.cache_by_default 布尔型
默认为On,但可以被设置为Off并和以加号开头的apc.filters配合使用,文件仅仅在匹配过滤器时才被缓存。
apc.filters 字符串
一个以逗号分割的POSIX扩展正则表达式的列表。如果任何模式匹配源文件名,这个文件将不会被缓存。注意用来匹配的文件名是传递给 include/require 的文件名,而不是绝对路径。如果正则表达式的第一个字符是 + ,则这个表达式就意味着任何匹配表达式的文件将会被缓存,如果第一个字符是 - 则任何匹配都不会被缓存。 - 是默认值,所以可以被省略。
原文地址:http://blog.sina.com.cn/s/blog_5f54f0be010126vc.html
相关文章推荐
- PHP OPCode缓存 APC详细介绍
- php 的opcode缓存apc以及其安装
- PHP OPCode缓存:APC详细介绍
- PHP-深入理解Opcode缓存
- 深入理解PHP Opcode缓存原理
- PHP OPCode缓存:APC详细介绍
- php的opcode缓存
- PHP代码的加密与OPcode缓存
- 加密PHP代码及PHP Opcode缓存小结
- 前端开发中的性能那点事(三)php的opcode缓存
- PHP缓存opcode加速之APC配置使用介绍 (深入理解)
- 前端开发中的性能那点事(三)php的opcode缓存
- PHP脚本批量清除nginx缓存的方法
- PHP Opcode缓存总结
- 深入理解PHP Opcode缓存原理
- php opcode缓存之apc
- php 脚本缓存 apc配置
- 前端开发中的性能那点事(三)php的opcode缓存
- php opcode缓存
- 黄聪:深入理解PHP Opcode缓存原理