简单的数据缓存技术[转一] .=) *Qx+
XW+-E^d
简单的数据缓存技术 =E:sEw2j
4 b}'W}
近来做了一阵子程序性能的优化工作,有个比较有意思的想法,想提出来和大家交流一下。 NOf{Xx<#k
Cache是“以空间换时间”策略的典型应用模式,是提高系统性能的一种重要方法。缓存的使用在大访问量的情况下能够极大的减少对数据库操作的次数,明显降低系统负荷提高系统性能。相比页面的缓存,结果集是一种“原始数据”不包含格式信息,数据量相对较小,而且可以再进行格式化,所以显得相当灵活。由于PHP是“一边编译一边执行”的脚本语言,某种程度上也提供了一种相当方便的结果集缓存使用方法——通过动态include相应的数据定义代码段的方式使用缓存。如果在“RamDisk”上建缓存的话,效率应该还可以得到进一步的提升。以下是一小段示例代码,供参考。 N:EljzvP}
=6N=5JePB
<? fc4jbPp:M
// load data with cache +e#(p<
function load_data($id,$cache_lifetime) { /=QsZ,~xo
Wxgs66
// the return data =@nW;PUZ
$data = array(); G0Z$p6z
s !II}'Je
// make cache filename ]qx!51S
$cache_filename = ‘cache_‘.$id.‘.php‘; ^;$9>yi1
v7v>
// check cache file‘s last modify time q?8#D
$cache_filetime = filemtime($cache_filename); [q^pMH#U"
rEWuWv$
if (time() - $cache_filetime <= $cache_lifetime) { "$q"Kilj%
//** the cache is not expire ob/HO(h3
include($cache_filename); oWggh3eXk
} else { D\E"v,Y\+O
//** the cache is expired ~/Y8wxg
'1zC|:,
// load data from database ~`5[Li:eP
// ... SN`L@/I
while ($dbo->nextRecord()) { nO;ox*Bk+8
// $data[] = ... Np;tpq~
} MfA%Xep
@f-rS{
// format the data as a php file 5U*${
$data_cache = "<?\r\n"; xX~m Fz0C
while (list($key, $val) = each($data)) { NkQain9
$data_cache .= "\$data[‘$key‘]=array(‘"; 6K >(n
$data_cache .= "‘NAME‘=>\"".qoute($val[‘NAME‘])."\"," L>N)[;|
$data_cache .= "‘VALUE‘=>\"".qoute($val[‘VALUE‘])."\"" R5 EC/@
$data_cache .= ");\r\n"; v4\
m9Pu4
} Ey_mK\'
$data_cache = "?>\r\n"; WK.,q>#
nVGOhYn
// save the data to the cache file \_+Af`
if ($fd = fopen($cache_filename,‘w+‘)) { 7j"B-k#
fputs($fd,$data_cache); fUJe{C<H
fclose($fd); 5!6}g<z&L
} f%REN3=5K
} GB}X
return $data; y;hco
} }-vP~I
?> ^SS9BQ*m
^(:n a6C
适用情况: %F<3_#Y
1.数据相对比较稳定,主要是读取操作。 t'C9;
2.文件操作要比数据库操作快。 `2'*E\
3.复杂数据访问,大数据量访问,密集数据访问,系统数据库负载极重。 f&XM|Bg
4.Web/DB分离结构或者多Web单DB结构。 + Cq&~<B
eqpnh^0}d
未经证实的问题: iT1HbAT]
1.并发访问时对文件的读写是否会引起锁定问题。 wh^I|D?"
2.涉及到的数据文件太多时,性能如何。 \d w ["k
/!y3ZzL
扩展思路: Fd._D"
1.生成JavaScript数据定义代码,在客户端调用。 {[+Q\<