简单的数据缓存技术[转一] b3GTsX\2|
NY[48H
简单的数据缓存技术 3],(oQq^
FY+@fy
近来做了一阵子程序性能的优化工作,有个比较有意思的想法,想提出来和大家交流一下。 ecp0 hG`%
Cache是“以空间换时间”策略的典型应用模式,是提高系统性能的一种重要方法。缓存的使用在大访问量的情况下能够极大的减少对数据库操作的次数,明显降低系统负荷提高系统性能。相比页面的缓存,结果集是一种“原始数据”不包含格式信息,数据量相对较小,而且可以再进行格式化,所以显得相当灵活。由于PHP是“一边编译一边执行”的脚本语言,某种程度上也提供了一种相当方便的结果集缓存使用方法——通过动态include相应的数据定义代码段的方式使用缓存。如果在“RamDisk”上建缓存的话,效率应该还可以得到进一步的提升。以下是一小段示例代码,供参考。 7
X~JLvN
DuQ:82 3b
<? X0$?$ta
// load data with cache $'a]lR
function load_data($id,$cache_lifetime) { +}-cvM/*
^ilgd
// the return data 2v*X^2+
$data = array(); QYBLU7
bX%4[BKP
// make cache filename eo"XHP7ja
$cache_filename = ‘cache_‘.$id.‘.php‘; &Fmen;(
')fIa2dO/
// check cache file‘s last modify time dsK^-e6:5
$cache_filetime = filemtime($cache_filename); GsqO^SV
$VxuaOTyVZ
if (time() - $cache_filetime <= $cache_lifetime) { r9-)+R
J
//** the cache is not expire WCI'Kh
include($cache_filename); PCKxo;bD
} else { |ew:}e: k<
//** the cache is expired kY~yA2*G
,fm{
krE
// load data from database TjctK [db@
// ... KZ [:o,jp>
while ($dbo->nextRecord()) { }L5;=A']S
// $data[] = ... :f R GXrn
} g87M"kQKA
U4e9[=q`'
// format the data as a php file z-S8s2.Fd
$data_cache = "<?\r\n"; 7H[.o~\
while (list($key, $val) = each($data)) { 6SSrkj }U
$data_cache .= "\$data[‘$key‘]=array(‘"; # kmI#W"^
$data_cache .= "‘NAME‘=>\"".qoute($val[‘NAME‘])."\"," 6<n+p'+n
$data_cache .= "‘VALUE‘=>\"".qoute($val[‘VALUE‘])."\"" ia-&?
$data_cache .= ");\r\n"; ,=}+.ax
} mx^rw*'JGC
$data_cache = "?>\r\n"; F@X8a/;F-
0@#d($'1?Z
// save the data to the cache file @y# u!}
if ($fd = fopen($cache_filename,‘w+‘)) { JCITIjD7=
fputs($fd,$data_cache); CT{X$N
fclose($fd); f%STkL)
} IS!]!s'EI
} &gvX<X4e
return $data; mgEZiAV ?
} 4-xg+*()
?> Cz4l
r*ry8QA
适用情况: OgyHX>}bH
1.数据相对比较稳定,主要是读取操作。 Bq\WG=Fd
2.文件操作要比数据库操作快。 /9C>{29x!
3.复杂数据访问,大数据量访问,密集数据访问,系统数据库负载极重。 jATN):8W
4.Web/DB分离结构或者多Web单DB结构。 gHU0Pr9'
s3 gT6
未经证实的问题: & =vi]z:[
1.并发访问时对文件的读写是否会引起锁定问题。 {Hxziyv~Y(
2.涉及到的数据文件太多时,性能如何。 MCfDR#a
T:udw
扩展思路: N8]d0
1.生成JavaScript数据定义代码,在客户端调用。 Y{m1\s/ o
2.还未想到……