Cache是“以空间换时间”策略的典型应用模式,是提高系统性能的一种重要方法。缓存的使用在大访问量的情况下能够极大的减少对数据库操作的次数,明显降低系统负荷提高系统性能。相比页面的缓存,结果集是一种“原始数据”不包含格式信息,数据量相对较小,而且可以再进行格式化,所以显得相当灵活。由于PHP是“一边编译一边执行”的脚本语言,某种程度上也提供了一种相当方便的结果集缓存使用方法——通过动态include相应的数据定义代码段的方式使用缓存。如果在“RamDisk”上建缓存的话,效率应该还可以得到进一步的提升。以下是一小段示例代码,供参考。
1
function load_data($id,$cache_lifetime) {
2
3
// the return data
4
5
$data = array();
6
7
// make cache filename
8
9
$cache_filename = ‘cache_‘.$id.‘.php‘;
10
11
// check cache file‘s last modify time
12
13
$cache_filetime = filemtime($cache_filename);
14
15
if (time() - $cache_filetime <= $cache_lifetime) {
16
17
//** the cache is not expire
18
19
include($cache_filename);
20
21
} else {
22
23
//** the cache is expired
24
25
// load data from database
26
27
//
28
29
while ($dbo->nextRecord()) {
30
31
// $data[] =
32
33
}
34
35
// format the data as a php file
36
37
$data_cache = "
38
39
while (list($key, $val) = each($data)) {
40
41
$data_cache .= "$data[‘$key‘]=array(‘";
42
43
$data_cache .= "‘NAME‘=>"".qoute($val[‘NAME‘])."\","
44
45
$data_cache .= "‘VALUE‘=>\"".qoute($val[‘VALUE‘])."\""
46
47
$data_cache .= ";);";
48
49
}
50
51
$data_cache = "?>";
52
53
// save the data to the cache file
54
55
if ($fd = fopen($cache_filename,‘w+‘)) {
56
57
fputs($fd,$data_cache);
58
59
fclose($fd);
60
61
}
62
63
}
64
65
return $data;
66
67
}
68
69
?>
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
适用情况:
1.数据相对比较稳定,主要是读取操作。
2.文件操作要比数据库操作快。
3.复杂数据访问,大数据量访问,密集数据访问,系统数据库负载极重。
4.Web/DB分离结构或者多Web单DB结构。
////////////补充
1
<?php
2
function cache_isvalid($cacheid,$expire=300) {
3
@clearstatcache();
4
if (!@file_exists($cacheid)) return false;
5
if (!($mtime=@filemtime($cacheid))) return false;
6
$nowtime=mktime();
7
if (($mtime+$expire)<$nowtime) {
8
return false;
9
}else{
10
return true;
11
}
12
}
13
14
function cache_write($cacheid,$cachecontent) {
15
$retry=100;
16
for ($i=0;$i<$retry;$i++) {
17
$ft=@fopen($cacheid,"wb");
18
if ($ft!=false) break;
19
if ($i==($retry-1)) return false;
20
}
21
@flock($ft,LOCK_UN);
22
@flock($ft,LOCK_EX|LOCK_NB);
23
for ($i=0;$i<$retry;$i++) {
24
$tmp=@fwrite($ft,$cachecontent);
25
if ($tmp!=false) break;
26
if ($i==($retry-1)) return false;
27
}
28
@flock($ft,LOCK_UN);
29
@fclose($ft);
30
@chmod($cacheid,0777);
31
return true;
32
}
33
34
function cache_fetch($cacheid) {
35
$retry=100;
36
for ($i=0;$i<$retry;$i++) {
37
$ft=@fopen($cacheid,"rb");
38
if ($ft!=false) break;
39
if ($i==($retry-1)) return false;
40
}
41
$cachecontent='';
42
while (!@feof($ft)) {
43
$cachecontent.=@fread($ft,4096);
44
}
45
@fclose($ft);
46
return $cachecontent;
47
}
48
49
function cache_clear_expired($cachedirname,$expire=300) {
50
$cachedir=@opendir($cachedirname);
51
while (false!==($userfile=@readdir($cachedir))) {
52
if ($userfile!="." and $userfile!=".." and substr($userfile,-4,4)=='.htm') {
53
$cacheid=$cachedirname.'/'.$userfile;
54
if (!cache_isvalid($cacheid,$expire)) @unlink($cacheid);
55
}
56
}
57
@closedir($cachedir);
58
}
59
60
?>
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60