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等可以帮我们实现。
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 的文件名,而不是绝对路径。如果正则表达式的第一个字符是 +
,则这个表达式就意味着任何匹配表达式的文件将会被缓存,如果第一个字符是 - 则任何匹配都不会被缓存。 -
是默认值,所以可以被省略。