V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
xiamuguizhi
V2EX  ›  分享创造

Typecho 主题“simplifier”全站静态缓存版本

  •  
  •   xiamuguizhi ·
    xiamuguizhi · 2021-05-03 15:27:34 +08:00 · 2903 次点击
    这是一个创建于 1327 天前的主题,其中的信息可能已经有所发展或是发生改变。

    前言

    这个主题样式就那样,主要是给大家提供一个全站静态化思路!你可以参考这个主题去修改你现在的主题,然后全站自动化生成静态。

    ps:我测试了所有主题都可以这样改,URL 什么格式都可以!!!

    使用

    1. 在网站 根目录 新建 文件夹 “cache” 作为缓存文件存放,记得设置777 权限

    2. chmod -Rf 777 /usr/themes/simplifier/ 简单暴力,让生成的缓存文件有写入权限

    3. 复制gengxinwenzhang.php 复制或者移动到根目录 这个是手动更新文章

    说明

    预览地址: https://9i3.cn/ 目前15w 文章都是缓存文件 不读取数据库

    文章缓存核心代码

    <?php
    
      $pageURL = 'http';
     
      if ($_SERVER["HTTPS"] == "on") 
      {
        $pageURL .= "s";
      }
      $pageURL .= "://";
     
    
        $pageURL .= $_SERVER["SERVER_NAME"] . $_SERVER["REQUEST_URI"];
    
    $shouye = $this->options->siteUrl;
    $post = str_replace($shouye,"",$pageURL);
    $post = str_replace(".html","",$post);	
    $post = str_replace("/","",$post);
    $cache= "cache/" . $post;
    $filename = $cache;
     
    //定义缓存有效期
    $cachetime = 259200; //设置缓存三天,三天后有人访问再次生成最新 三天
     
    //判断缓存文件是否存在
    if(!file_exists($filename) || filemtime($filename)+$cachetime<time())  //filemtime($filename)获取文件修改时间,加上定义的缓存时间小于当前时间
    {
         //开启内存缓存
        ob_start();
     
    ?>
    <?php $this->need('post-html.php'); ?>
     
    <?php
      //从内存缓存中获取页面代码
        $content = ob_get_contents();
        $content .= "\n<!-- 缓存于: " . date( 'Y-m-d H:i:s' ) . " -->";
        //将获取到的内容存放到缓存文件
        file_put_contents($filename,$content);
         
        //清掉内存缓存
        ob_flush();   
     
    }
    else
    {
         include($filename);  //如果存在,调用缓存文件
    }
     
    ?>
    <?php $this->need('comments.php'); //不缓存评论 ?>  
    <?php $this->need('footer.php'); ?>
    

    首页核心代码

    <?php
    
    $filename = "index.htm";
     
    //定义缓存有效期
    $cachetime = 10800;
     
    //判断缓存文件是否存在
    if(!file_exists($filename) || filemtime($filename)+$cachetime<time())  //filemtime($filename)获取文件修改时间,加上定义的缓存时间小于当前时间
    {
         //开启内存缓存
        ob_start();
     
    ?>
    <?php $this->need('index-html.php'); ?>
     
    <?php
      //从内存缓存中获取页面代码
        $content = ob_get_contents();
        $content .= "\n<!-- 缓存于: " . date( 'Y-m-d H:i:s' ) . " -->";
        //将获取到的内容存放到缓存文件
        file_put_contents($filename,$content);
         
        //清掉内存缓存
        ob_flush();   
     
    }
    else
    {
         include($filename);  //如果存在,调用缓存文件
    }
     
    ?>
    <?php else: ?>
    <?php
    
      $pageURL = 'http';
     
      if ($_SERVER["HTTPS"] == "on") 
      {
        $pageURL .= "s";
      }
      $pageURL .= "://";
     
    
      $pageURL .= $_SERVER["SERVER_NAME"] . $_SERVER["REQUEST_URI"];
    
    $shouye = $this->options->siteUrl;
    $post = str_replace($shouye,"",$pageURL);
    $post = str_replace(".html","",$post);	
    $post = str_replace("/","",$post);
    $cache= "cache/" . $post;
    $filename = $cache;
     
    //定义缓存有效期
    $cachetime = 86400;
     
    //判断缓存文件是否存在
    if(!file_exists($filename) || filemtime($filename)+$cachetime<time())  //filemtime($filename)获取文件修改时间,加上定义的缓存时间小于当前时间
    {
         //开启内存缓存
        ob_start();
     
    ?>
    <?php $this->need('index-html.php'); ?>
     
    <?php
      //从内存缓存中获取页面代码
        $content = ob_get_contents();
        $content .= "\n<!-- 缓存于: " . date( 'Y-m-d H:i:s' ) . " -->";
        //将获取到的内容存放到缓存文件
        file_put_contents($filename,$content);
         
        //清掉内存缓存
        ob_flush();   
     
    }
    else
    {
         include($filename);  //如果存在,调用缓存文件
    }
     
    ?>
    
    <?php endif; ?>			
    

    下载地址

    Github:https://github.com/xiamuguizhi/typecho_simplifier_cache

    本站:https://qq.md/posts/120.html

    10 条回复    2021-05-06 12:10:34 +08:00
    mrgeneral
        1
    mrgeneral  
       2021-05-03 18:39:14 +08:00
    Typecho 本身设计不属于 JAMstack,单纯的页面缓存没办法解决评论、阅读数等动态数据,并且文章的变动还涉及到分类、日期归档、翻页等数据的联动,需要很复杂的缓存更新策略才能做到比较好的体验。

    目前能做到比较好的体验是热点 Cache + CDN 体系,纯静态还是差点意思。

    最后,[我也迁移到 Hexo 了]( https://www.chengxiaobai.com/trouble-maker/migrate-to-hexo),真香 /狗头
    xiamuguizhi
        2
    xiamuguizhi  
    OP
       2021-05-03 19:00:45 +08:00
    @mrgeneral https://weebs.neocities.org/ 纯净态评论差点意思我又转回来了。
    falcon05
        3
    falcon05  
       2021-05-03 19:08:38 +08:00 via iPhone
    同意一楼,其实这个难度不在生成上,而是在更新策略上
    Azure99
        4
    Azure99  
       2021-05-03 19:08:57 +08:00   ❤️ 2
    其实 WordPress 和 Typecho 这种动态 CMS 可以考虑用 nginx 的 fastcgi 缓存+一套自己的清除机制。
    命中缓存时只走 nginx,可以带来媲美静态博客的速度,然后针对文章变动(涉及分页、分类、归档等)、评论变动(文章页)去动态清理缓存,效果会很不错。
    而对于有大量文章且频繁更新的,比如 lz 这种采集站?新文章的发布必然导致频繁的缓存失效 or 不一致(二选一),还是更建议在持久层做 cache 。PS:这种情况静态生成器也不能很好胜任。

    多说无益,可以看一下效果,使用 WordPress 速度还凑合 https://www.rainng.com/
    Outshine
        5
    Outshine  
       2021-05-05 00:26:42 +08:00
    @Azure99 测试了一下,速度确实飞快
    bensky
        6
    bensky  
       2021-05-05 10:00:00 +08:00
    @xiamuguizhi 其实现在普通个人网站每天能有几个评论。。
    tbg
        7
    tbg  
       2021-05-05 20:50:01 +08:00
    @Azure99 速度这么快,有没有详细的优化教程👍
    Azure99
        8
    Azure99  
       2021-05-05 22:29:40 +08:00   ❤️ 1
    @tbg 基本都是老生常谈的几个点。
    首先是降低服务器响应时间,这里直接上缓存后,响应速度与静态页面无异。
    第二是减少首屏资源,比如我网站的首屏资源只有文档跟一个主要 css 加起来大约 40kb,其他诸如 fontawesome 图标库、以及实现各种交互功能的 js 统统延迟加载,不要阻塞首屏渲染。
    如果条件允许,可以针对首屏资源上 ServerPush,将文档和首屏资源同时推送给用户,减少一个 RTT 。
    针对静态资源可以上 CDN,如果没有做动静分离的话,动态资源回源可能会慢很多,推荐用阿里云 /百度云的动态加速,原理很简单,就是动态资源绕过中间缓存节点,然而国内做的好的只有这两家,别家基本都是动态减速。
    此外,还可以耍一些小把戏,比如在桌面端鼠标悬停时 /移动端手指触摸时就预加载页面,能够争取几十 ms 的时间,instant.page 是一种实现,可以参考一下
    xiamuguizhi
        9
    xiamuguizhi  
    OP
       2021-05-06 12:09:16 +08:00
    @Azure99 哈哈 这个其实很简单的 第一次访问 就生成一个 txt 文件 存放在 cache 文件夹 第二次访问就直接 读取这个文件夹 txt 文件 ....
    xiamuguizhi
        10
    xiamuguizhi  
    OP
       2021-05-06 12:10:34 +08:00
    @bensky 那个站点是我做实验的平时没管理,https://qq.md/ 这个才是我个人博客,欢迎互访。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2184 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 16:11 · PVG 00:11 · LAX 08:11 · JFK 11:11
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.