php opcode修改,PHP--opcode 脚本缓存

本文介绍了PHP与C/C++在执行效率上的差异,C/C++编译后的二进制文件运行速度快,而PHP是解释型语言,依赖解释器执行。解释器将PHP代码转换为opcode执行,这一过程消耗资源。为了优化PHP性能,文章提到了如APC、eAccelerator和XCache等缓存技术,它们能缓存opcode以减少解释成本。通过安装和配置这些扩展,可以显著提高PHP应用程序的运行速度。
摘要由CSDN通过智能技术生成

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

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

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

会输出结果:333

a4c26d1e5885305701be709a3d33442f.png

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;'));"

结果如下图:

a4c26d1e5885305701be709a3d33442f.png

a4c26d1e5885305701be709a3d33442f.png

a4c26d1e5885305701be709a3d33442f.png

后面还有很长。但可以看到,结果是以数组形式返回的。而且红框中标识的就是一些关键语法,如: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 的文件名,而不是绝对路径。如果正则表达式的第一个字符是 +

,则这个表达式就意味着任何匹配表达式的文件将会被缓存,如果第一个字符是 - 则任何匹配都不会被缓存。 -

是默认值,所以可以被省略。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值