PHP--opcode 脚本缓存

C/C++将动态内容编译成二进制可执行文件(目标代码),由操作系统进程直接装载运行,速度非常快。但PHP等语言不是编译型,而是解释型,它们不直接由操作系统来运行,而是由专门的解释器来运行,而解释器则由操作系统运行。

PHP由一个二进执行文件,如:/usr/local/php/bin/php 来执行。在执行过程中,解释器对代码进行分析,然后进行运算。比如,我们在命令行中输入:

/usr/bin/php -r 'echo 333;'

会输出结果:333



PHP解释器先分析我们输入的 echo 333;然后将它们生成可以直接运行的中间代码,也称操作码:Operate Codeopcode

要查看PHPopcode要先安装 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有诸如APCeAcceleratorXCache 等可以帮我们实现。


 

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.可根据服务器的实际情况来调整,163264128都是可以的。

 

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值