• 豆博今天增加了 Railgun 来加速博客动态文件了,折腾了半天终于完成!

  • 感觉上好久都没换新衣服了,换个新衣服,换个好心情吧!

wordpress非插件实现生成静态缓存文件,提速效率高达100%

豆子收集 豆子 2年前 (2019-04-30) 285次浏览 已收录 0个评论 扫描二维码

在大量文章、评论以及插件的数据的情况下wordpress速度的确不敢恭维。豆子实在受不了,看看有没有不要插件来静态化缓wordpress。解决的办法。

< ?php 
define('CACHE_ROOT', dirname(__FILE__).'/cache'); 
define('CACHE_LIFE', 86400); //缓存文件的生命期,单位秒,86400 秒是一天 
define('CACHE_SUFFIX','.html'); //缓存文件的扩展名,千万别用 .php .asp .jsp .pl 等等 

$file_name = md5($_SERVER['REQUEST_URI']).CACHE_SUFFIX; //缓存文件名 
//缓存目录,根据 md5 的前两位把缓存文件分散开。避免文件过多。如果有必要,可以用第三四位为名,再加一层目录。
 //256 个目录每个目录 1000 个文件的话,就是 25 万个页面。两层目录的话就是 65536*1000=六千五百万。 
//不要让单个目录多于 1000,以免影响性能。 

$cache_dir = CACHE_ROOT.'/'.substr($file_name,0,2); 
$cache_file = $cache_dir.'/'.$file_name; //缓存文件存放路径 

if($_SERVER['REQUEST_METHOD']=='GET'){ //GET 方式请求才缓存,POST 之后一般都希望看到最新的结果 
if(file_exists($cache_file) && time() - filemtime($cache_file) < CACHE_LIFE){ //如果缓存文件存在,并且没有过期,就把它读出来。
$fp = fopen($cache_file,'rb');
fpassthru($fp);
fclose($fp);
exit();
}
elseif(!file_exists($cache_dir)){
if(!file_exists(CACHE_ROOT)){
mkdir(CACHE_ROOT,0777);
chmod(CACHE_ROOT,0777);
}
mkdir($cache_dir,0777);
chmod($cache_dir,0777);
}
function auto_cache($contents){
//回调函数,当程序结束时自动调用此函数
global $cache_file;
$fp = fopen($cache_file,'wb');
fwrite($fp,$contents);
fclose($fp);
chmod($cache_file,0777);
clean_old_cache(); //生成新缓存的同时,自动删除所有的老缓存。以节约空间。
return $contents;
}
function clean_old_cache(){ chdir(CACHE_ROOT);
foreach (glob("*/*".CACHE_SUFFIX) as $file){
if(time()-filemtime($file)>CACHE_LIFE){ unlink($file);
 }
 }
 }
 ob_start('auto_cache'); //回调函数
auto_cache }
 else{ 
if(file_exists($cache_file)){
 //file_exists() 函数检查文件或目录是否存在。 
unlink($cache_file);
 //不是 GET 的请求就删除缓存文件。
 }
 }
 ?>

将以上代码保存为 cache.php 文件然后放置到网站根目录,然后在根目录下目录下一个名为 cache 的目录,权限更改为 777(写入缓存文件用的)

然后在根目录的 index.php 的< ?php 之后加上以下代码:

require('cache.php');

一定要保证缓存目录的可写性,一定要加到文件的最上方,不然等页面完全加载完了才吐出缓存页面那就等于没缓存一样。


豆博 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA4.0 协议进行授权
转载请注明原文链接:wordpress非插件实现生成静态缓存文件,提速效率高达100%
喜欢 (2)
[sablog@yahoo.cn]
分享 (0)
豆子
关于作者:
豆博站长
发表我的评论
取消评论
声明: 本博采用 BY-NC-SA 协议进行授权
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址