Cloudflare Workers + KV 搭建一个带后台管理的blog
本文最后更新于 2024-06-12,
若内容或图片失效,请留言反馈。部分素材来自网络,若不小心影响到您的利益, 请联系我 删除。
本站只有Telegram群组为唯一交流群组, 点击加入
文章内容有误?申请成为本站文章修订者或作者? 向站长提出申请
展示
本文部分内容由chatgpt生成,略有修改
相关链接:
Github:https://github.com/wang-useful/cfblog-plus
(备注:本文介绍的是 cfblog-plus
原仓库为:https://github.com/Arronlong/cfblog-plus ,是gdtool/cloudflare-workers-blog 的一个修改版)
1.介绍
cf blog
是一个运行在cloudflare workers 上的博客程序,使用 cloudflare KV作为数据库,无其他依赖. 兼容静态博客的速度,以及动态博客的灵活性,您可以通过访问项目仓库了解更多详情。
2.项目特点:
- 使用workers提供的KV作为数据库,可达到wordpress的灵活性
- 使用cloudflare缓存html来降低KV的读写,使其可达到静态博客的速度
- 后台使用markdown语法,方便快捷,一键发布(页面重构+缓存清理)
cfblog-plus
新增了文章置顶、后台首页选择、文章隐藏、静态搜索<span> </span>
等功能
3.部署
-
第一步:注册Cloudflare账号
Cloudflare官网:https://dash.cloudflare.com -
第二步,将域名托管到CloudFlare中,并获取
区域ID
如果没有也行,可以使用自动分配的域名,但是后续发布文章时,自动清除缓存会无法使用,问题不大
托管域名:过程略,自行baidu或google
获取区域ID:如域名已托管到CloudFlare中,进入域名站点管理页面,页面向下滑动,记录右侧的“区域ID”的值,后续会用到。 -
第三步,获取清除缓存 API 令牌
打开API令牌管理页面,点击“创建令牌”按钮,页面拉到最下面,点击“创建自定义令牌”后面的“开始使用”按钮,按以下方式填写。
令牌名字:CFBlog-plus
缓存权限:区域 -> 缓存清除 -> 清除
区域资源:包括 -> 特定区域 -> 【您的域名】
- token留下备用
- 第四步,新建KV命名空间
打开CloudFlare主页,点击右侧的“Workers”,然后点击“KV”项,即可进入“Worker KV”管理页面。
在命名空间名称输入框里任意输入一个名称,为了见名知义,这里最好使用CFBLOG作为命名空间名称。点击添加即可。如下图所示:
第五步,创建Workers
点击挨着“KV”的“概述”项,进入Workers 和 Pages 概述,点击“创建应用程序”,点击“创建Workers”,点击“编辑代码”
将index_plus.js中的内容替换workers的内容。
先不修改配置,然后点击“保存并部署”。然后点击“<”箭头,返回该workers的配置页面,自行“重命名”,然后“设置”--"变量"选项卡,添加“KV 命名空间绑定”,变量名随意起,推荐用CFBLOG,下拉选择新添加的KV命名空间,点击“保存按钮”。
再将页面滑动上面,点击“快速编辑”,重新打开workers的编辑页面开始添加各类配置。
- 以上配置项均根据配置说明进行配置即可,不再详细说明。要记得“保存并部署”
可以点击右侧的“预览”选项卡进行预览,能成功出现页面就说明配置成功了。 - 第六步,配置域名访问【非必须】
- 参照图片
保存后可以看到列表里有刚添加的信息,自此,所有配置已经完成,可以愉快的写博客了。
4.可能遇到的问题
- 文章id为
ID000nan
且访问会报错误
解决方案:在创建的KV中修改SYSTEM_INDEX_NUM
的值为0
- 新增文章时,必填的分类无法选择
解决方案:在顶部设置
中,参照提示填写分类 - 保存了,但是主页不显示文章
解决方案:在后台直接点发布或者去Cloudlfare清除相关链接的缓存(自行baidu/Google)
5.扩展
添加评论、阅读量、内容分类、页脚、自定义页面和图标、链接等,请自行发掘
例子
页脚(可以把作者信息保留,我这里因为有这篇文章介绍就不保留了)
阅读量
评论
图标+分类
.承载能力:
- KV基本不存在瓶颈,因为使用了缓存,读写很少
- 唯一瓶颈是 workers的日访问量10w,大约能承受2万IP /日
- 文章数:1G存储空间,几万篇问题不大
7.说明
感谢原作者的付出,觉得好用不妨给原作者一个 星星