Typecho 主题“simplifier”全站静态缓存版本 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
xiamuguizhi
V2EX    分享创造

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

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

    前言

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

    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/ 纯净态评论差点意思我又转回来了。
    GG668v26Fd55CP5W
        3
    GG668v26Fd55CP5W  
       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     Solana     2729 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 24ms UTC 13:34 PVG 21:34 LAX 05:34 JFK 08:34
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86