php程序在抵抗大流量访问的时候动态网站往往都是难以招架,所以要引入缓存机制,一般情况下有两种类型缓存
一、文件缓存
二、数据查询结果缓存,使用内存来实现高速缓存
本例主要使用文件缓存。
主要原理使用缓存函数来存储网页显示结果,如果在规定时间里再次调用则可以加载缓存文件。
工具类代码:
1
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
// 文件缓存类
class Cache {
/**
* $dir : 缓存文件存放目录
* $lifetime : 缓存文件有效期,单位为秒
* $cacheid : 缓存文件路径,包含文件名
* $ext : 缓存文件扩展名(可以不用),这里使用是为了查看文件方便
*/
private $dir ;
private $lifetime ;
private $cacheid ;
private $ext ;
/**
* 析构函数,检查缓存目录是否有效,默认赋值
*/
function __construct( $dir = '' , $lifetime = 1800) {
if ( $this ->dir_isvalid ( $dir )) {
$this ->dir = $dir ;
$this ->lifetime = $lifetime ;
$this ->ext = '.Php' ;
$this ->cacheid = $this ->getcacheid ();
}
}
/**
* 检查缓存是否有效
*/
private function isvalid() {
if (! file_exists ( $this ->cacheid ))
return false;
if (! (@ $mtime = filemtime ( $this ->cacheid )))
return false;
if ( mktime () - $mtime > $this ->lifetime)
return false;
return true;
}
/**
* 写入缓存
* $mode == 0 , 以浏览器缓存的方式取得页面内容
* $mode == 1 , 以直接赋值(通过$content参数接收)的方式取得页面内容
* $mode == 2 , 以本地读取(fopen ile_get_contents)的方式取得页面内容(似乎这种方式没什么必要)
*/
public function write( $mode = 0, $content = '' ) {
switch ( $mode ) {
case 0 :
$content = ob_get_contents ();
break ;
default :
break ;
}
ob_end_flush ();
try {
file_put_contents ( $this ->cacheid, $content );
} catch ( Exception $e ) {
$this ->error ( '写入缓存失败!请检查目录权限!' );
}
}
/**
* 加载缓存
* exit() 载入缓存后终止原页面程序的执行,缓存无效则运行原页面程序生成缓存
* ob_start() 开启浏览器缓存用于在页面结尾处取得页面内容
*/
public function load() {
if ( $this ->isvalid ()) {
// 以下两种方式,哪种方式好?????
require_once ( $this ->cacheid);
echo "<!--缓存-->" ;
// echo file_get_contents($this->cacheid);
exit ();
} else {
ob_start ();
}
}
/**
* 清除缓存
*/
public function clean() {
try {
unlink ( $this ->cacheid );
} catch ( Exception $e ) {
$this ->error ( '清除缓存文件失败!请检查目录权限!' );
}
}
/**
* 取得缓存文件路径
*/
private function getcacheid() {
return $this ->dir . md5 ( $this ->geturl () ) . $this ->ext;
}
/**
* 检查目录是否存在或是否可创建
*/
private function dir_isvalid( $dir ) {
if ( is_dir ( $dir ))
return true;
try {
mkdir ( $dir , 0777 );
} catch ( Exception $e ) {
$this ->error ( '所设定缓存目录不存在并且创建失败!请检查目录权限!' );
return false;
}
return true;
}
/**
* 取得当前页面完整url
*/
private function geturl() {
$url = '' ;
if (isset ( $_SERVER [ 'REQUEST_URI' ] )) {
$url = $_SERVER [ 'REQUEST_URI' ];
} else {
$url = $_SERVER [ 'Php_SELF' ];
$url .= empty ( $_SERVER [ 'QUERY_STRING' ] ) ? '' : '?' . $_SERVER [ 'QUERY_STRING' ];
}
return $url ;
}
/**
* 输出错误信息
*/
private function error( $str ) {
echo '<div style="color:red;">' . $str . '</div>' ;
}
}
|
使用方法:
使用方法如下:
一部分代码放在要被缓存逻辑代码前面:
1
2
3
4
5
|
$cachedir = './Cache/' ; // 设定缓存目录
$cache = new Cache ( $cachedir , 33 ); // 省略参数即采用缺省设置, $cache = new Cache($cachedir);
if (@ $_GET [ 'cacheact' ] != 'rewrite' || @ $_GET [ 'clearCache' ] == 'ok' ) // 此处为一技巧,通过xx.Php?cacheact=rewrite更新缓存,以此类推,还可以设定一些其它操作
$cache ->load (); // 装载缓存,缓存有效则不执行以下页面代码
// 页面代码开始
|
一部分放在被缓存逻辑代码后面:
1
2
|
// 页面代码结束
$cache ->write (); // 首次运行或缓存过期,生成缓存
|
以上所述就是本文的全部内容了,希望大家能够喜欢。