采用 PEAR 来缓冲 PHP 程序 1}BW
5;C+K~Y
PHP 世界中缓冲是一个热门的话题,因为 PHP 产生的动态页面,每次用户请求都需要重新计算,不论请求的结果是否一样,同时,PHP 每次都会编译一次脚本。这样的超负荷运转对一个流量很高的网站来说肯定难以忍受。幸运的是, Web 的结果可以缓冲,而不需要重新运行和编译脚本,商品化的产品像 ZendCache 或者开源的 Alternate PHP Cache都提供了把 PHP 脚本编译为字节代码并缓冲的办法。 ki=-0G*]
l[L\|hv'n
PEAR 的缓冲包提供了缓冲动态内容,数据库查询和 PHP 函数调用的框架。 xgnt)&7T
Z/6B[,V
就像 Perl 有 CPAN, TeX 有 CTAN,PHP 也有自己的中心资源库,存放类,库和模块。这个库称为 PEAR(PHP Extension and Add-On Repository)。 ~z%K9YcyU
O=u.PRNT8
本文假设你已经安装了 PEAR 环境,如果没有的话,可以去 PHP 网站下载。 |j<b?
7AHEzJh"
ub0]nov
PEAR 的缓冲包包含一个总体的缓冲类和几个特别的子类。缓冲类使用容器类来存贮和管理缓冲数据。 #&5m=q$EI
(X QgOR#
下面是 PEAR 缓冲当前所包含的容器,以及各自的参数: =H3 JRRS
F=$2Gz
'RT
file -- file 容器在文件系统存储了缓冲的数据,是最快的容器。 D8C@x`
R0,
Q`
cache_dir -- 这是容器存储文件的目录。 b.Z K1
KP -g<Zc
filename_prefix -- 缓冲文件的前缀,例如:"cache_"。 # ]&=]K1V
T/dchWG
shm -- shm 容器把缓冲数据放入共享内存,基准测试显示,目前的实现下,这个容器的速度要比文件容器慢。 Qte=<Z)
d&PXJ
shm_key -- 共享内存使用的键值。 wQlK[F]!>
7V%}U5
shm_perm -- 使用共享内存数据段的权限。 _{TGO
jZr
G!L=W#{
shm_size -- 分配共享内存的大小。 Uw)?u$+
P
w<.{(1:v
sem_key -- 信号灯的键值。 >A7),6
9{^:+r
sem_perm -- 信号灯的权限。 0^?(;AK
.~4%TsBaY
db -- PEAR 的数据库抽象层。 g\OPidY
>-c ;
dsn -- 数据库连接的 DSN 。可以参考 PEAR 的 DB 文档。 Jou~>0,/j
i/NY86A
cache_table -- 表的名字。 +^1HtI|y
@;"HslU\Q
phplib -- phplib 容器使用数据库抽象层存储缓冲。 3)Wi?
-
VSc;}LH
db_class `LEk/b1(P
@{j'Pf'
db_file wk<QYLEk
tE/j3
db_path sX^m1v~N|
q{[}*%
local_file gmJiKuAL5
"AS;\-Jk
local_path %1 9TJn%J$
#(?EL@5
ext/dbx -- PHP 的数据库抽象层扩展,如果像把缓冲存入数据库,可以采用这个容器。 "|gNNmr
*+vS
f7
module s,\!@[N
Ha)eeE$
host @D[jUC$E
cP`o?:
db 9(dbou
;Bd0 =C
username 6-{QU] #
Sx5r u?$.
password >}\!'3)_
D[x0sly
cache_table 7N+No.vR.
3gQQ,V..
persistent dBE
:rZu
rg]eSP3W
使用 PEAR Cache 所得到的性能提升取决于你所选择的缓冲容器,例如,把数据库的结果再次存入数据库缓冲中就显得毫无意义。 ~T|?!zML
WFocA:
PEAR Cache 的函数缓冲模块能把任何函数或者方法的结果缓冲,不论是 PHP 的内置函数还是用户自定义函数,他缺省采用文件容器,把缓冲数据放入到一个叫做 aF1pq
function_cache 的目录。 MS%xOB*6
-\:pbR
m,K0BL
Cache_Function 类的构造器可以有三个可选的参数: nzmv>s&UW
v[T5D:
$container :缓冲容器的名字。 ~Y<x-)R
#qi@I;;t
$container_options :缓冲容器的数组参数。 MM"{ehd{^a
yk5-@qo
$expires:缓冲对象过期的时间(秒数)。 hs}nI/#
MR=>DcR
普通的函数调用采用 Cache_Function 类的 call() 方法时,就能触发缓冲。调用 call() 很容易,的一个参数是函数的名字,然后是函数的参数,第二个参数是要调用函数中的第一个,依此类推,我们来看例子: oIdMDp^$
dW
Y0
例 1: 缓冲函数和方法的调用 }Y~o =3-
r in#lu&N
// 调用 PEAR Cache 的函数缓冲。 KGS=(z
`PnB<rf:*1
<?php y&")7y/uE
require_once 'Cache/Function.php'; \/I@&$"F
,~w)~fMb8
// 定义一些类和函数。 }A'QXtI/G
y+\nj3v6
class foo { Lj6$?(x}
function bar($test) { xV @X%E
echo "foo::bar($test)<br>"; a*o#,T5A
} &uI`Xq.
} WUkx v*
}:P/eY
class bar { nyD(G=Q5
function foobar($object) { m7Nm!Z7
echo '$'.$object.'->foobar('.$object.') w&:"x@ -|
'; rIR~YMv!
} @jAuSBy
} OWT5Bjl
";AM3
$bar = new bar; nKC$
KC
xw(KSPN
function foobar() { pi[:"}m]/P
echo 'foobar()'; TXD\i Dq
} [H$rdh[+
wyeiz7
// 取得 Cache_Function 对象 Jf{6'Ub
eL[BH8l
$cache = new Cache_Function(); ^\Gaf5{
DfgqB3U[
// 对 foo 类的静态函数 bar() 作缓冲(foo::bar())。 v@TP_Ka
$cache->call('foo::bar', 'test'); H]K(`)y}4
$q);xs
// $bar->foobar() ;0( |06=
$cache->call('bar->foobar', 'bar'); (Vnv"= (
L6c=uN
$cache->call('foobar'); pwU
l&hwte
?> E+k#1c|v$
PB*mD7"
fl*]ua
%GQPiWu
下面我们采用 Cache_Output 来把输出作缓冲: yPL1(i;
gTcLS|&