我正在使用PHP HTML DOM Parser从外部网站拉取数据。为了减少负载并加快页面渲染时间,我希望将拉取的数据缓存一段时间。我该怎么做呢?
发布于 2011-05-18 10:57:03
我写了这个文件缓存函数,它基本上只是替换了file_get_contents。您可以在$offset中指定缓存应该持续的时间量,也可以使用$override完全覆盖缓存。如果不想使用/tmp/,只需将该目录更改为可读/写目录即可。
function cache_get_contents($url, $offset = 600, $override = false) {
$file = '/tmp/file_cache_' . md5($url);
if (!$override && file_exists($file) && filemtime($file) > time() - $offset)
return file_get_contents($file);
$contents = file_get_contents($url);
if ($contents === false)
return false;
file_put_contents($file, $contents);
return $contents;
}发布于 2011-05-18 10:32:56
您可以使用HTML语言创建本地文件,然后跟踪$SESSION中的文件路径。如果您有足够的磁盘空间并可以运行数据库,则可以使用数据库来做同样的事情。您正在查找的URL上的数据库连接和查询根本不会增加太多开销。
发布于 2011-05-18 10:33:09
一种方法是将数据保存到数据库或本地文件中。然后,您可以使用时间戳列或文件修改时间来确定是继续使用缓存还是拉入并保存新的副本。
如果你可以访问某种类型的内存缓存(例如memcached),那将是最理想的。
https://stackoverflow.com/questions/6039230
复制相似问题