PHP Cache文件缓存机制及其缓存原理详解,使用 PEAR 中的 cache 可以将内容缓存于文件,数据库或者内存中,以文件为例。
没有使用缓存
pear_content_cache1.php
以下为引用内容:
<?php
echo "这是内容。<P>";
echo "当前时间是" . date('M-d-Y H:i:s A', time()) . "<BR>";
?>
为其加上缓存
pear_content_cache2.php
以下为引用内容:
<?php
require_once 'Cache/Output.php';
//设置缓存目录,必须是可写的
$cacheDir = './pear_cache';
$cache = new Cache_Output('file',array('cache_dir' => $cacheDir));
//如果nocache变量为空,使用缓存中的内容
//如果想获得最新的内容,就要赋值给nocache变量
if (empty($_REQUEST['nocache']))
{
// 建立一个独一的cache标识
// 请求+Cookie信息
$cache_id = $cache->generateID(array('url' => $_REQUEST,'post' =>$_POST,'cookies' => $HTTP_COOKIE_VARS));
}
else
{
//想获得最新的内容,ID为空
$cache_id = null;
}
//看cache ID对应的缓存内容是否可用
if ($content = $cache->start($cache_id))
{
//缓存已存在,直接输出,并结束脚本
echo $content;
exit();
}
// 缓存中不存在该内容,生成新内容并写入缓存
echo "这是内容。<P>";
echo "当前时间是" . date('M-d-Y H:i:s A', time()) . "<BR>";
// 把内容写入缓存
echo $cache->end();
?>
分别刷新这两个文件,你会发现 pear_content_cache1.php 中的“当前时间是”这一行中的时间是随着刷新而变化的,而 pear_content_cache2.php 中的这一行则不变。
这是由于 pear_content_cache2.php 使用了缓存,将用户请求的内容存入静态文件中。当用户再次请求时,它直接从文件中输出,而不需要用程序动态生成内容。
对于 pear_content_cache2.php ,如果用户想要读取最新的信息,而不是缓存中成旧的信息。那么可以用http.//…/pear_content_cache2.php?nocache=1 来访问,这将禁用缓存功能,刷新一下看看,你将发现时间会随之变化。
总结PEAR内容缓存类的使用:
1、包含 PEAR 包 要注意路径。
2、包含Output.php中的cache类
以下为引用内容:
require_once 'Cache/Output.php';
3、设置缓存目录
以下为引用内容:
$cacheDir = './pear_cache';
确认这个目录是可写的,Cache数据将会写入这个目录的子目录中。
4、建立一个输出缓存对象
以下为引用内容:
$cache = new Cache_Output('file',array('cache_dir' => $cacheDir));
第一个参数表示我们使用基于“文件”方式的缓存,第二个参数是一个与缓存目录相关联的数组。
5、产生一个唯一的cache ID
以下为引用内容:
$cache_id = $cache->generateID(array('url' => $_REQUEST,'post' =>$_POST,'cookies' => $HTTP_COOKIE_VARS));
这里 $cache 对象的 generateID() 方法通过提供一个信息数组 (URL, HTTP POST data, 和 HTTP cookie) 来独一无二地标识这个请求,与其它请求区分开来。
6、增加一个逻辑判断语句看是否对应于cacheID的缓存数据是否已经存在,如果存在,获取数据并结束脚本。
以下为引用内容:
if ($content = $cache->start($cache_id))
{
echo $content;
exit();
}
7、将产生内容的代码放在以上逻辑语句之后,并结束使用cache对象。
以下为引用内容:
echo $cache->end();
函数缓存输出 PEAR cache
PEAR除了可以对输出的内容进行缓存处理外,还可以将对某个函数的调用结果缓存起来。这是个很有趣的功能,如果你的程序要频繁使用到某个函数,而且调用的结果相同的话,我建议你不妨试试,特别是当这个函数运行起来比较慢的时候。
下面我们实现对一个执行起来很慢的函数 slowFunction() 的缓冲调用。
以下为引用内容:
<?php
require_once 'Cache/Function.php';
$cacheDir = './pear_cache/';
$cache = new Cache_Function('file',array('cache_dir' => $cacheDir));
$arr = array('东方', '南方','西方');
$cache->call('slowFunction', $arr);
echo '<BR>';
$arr = array('东方', '南方','西方');
slowFunction($arr);
function slowFunction($arr = null)
{
echo "执行起来很慢的函数 :( <br>";
echo "当前时间是 " . date('M-d-Y H:i:s A', time()) . '<br>';
foreach ($arr as $fruit)
{
echo "太阳此时正在 $fruit <br>";
}
)
?>
以下是示例的脚本执行结果:
执行起来很慢的函数:
- 当前时间是 Jul-28-2010 17:15:57 PM
- 太阳此时正在 东方
- 太阳此时正在 南方
- 太阳此时正在 西方
执行起来很慢的函数 :
- 当前时间是 Jul-28-2010 17:17:55 PM
- 太阳此时正在 东方
- 太阳此时正在 南方
- 太阳此时正在 西方
代码中,Cache/Function.php 类用来执行函数缓冲功能,$cache变量是一个 Cache_Function 对象,使用基于文件的函数缓存,存入 $cacheDir 目录。要缓存一个函数调用,Cache_Function 对象 $cache 的 call() 方法要像这样使用:
以下为引用内容:
$cache->call(‘slowFunction’, $arr);
这里,slowFunction() 函数被调用,参数为一个数组 $arr ,这个函数被缓存在 $cacheDir 目录下的一个文件里。任何在此之后的对这个函数的调用,将会由 $cache->call() 返回该函数执行的结果。