开源工具、效率方法、心理学探索的自我提升笔记

Table of Contents

✨ 初衷

曾经,我把知识记录在 Notion、Obsidian、飞书等知识管理软件上,散落各处,使用起来很麻烦,也难以对外分享。

但是,笔记里的知识并不属于你,只有经过消化、应用,才会成为自己的知识。

因此,我基于 VuePress 和 vuepress-theme-hope 建立了 LearnData,将所有笔记与文章聚合在同一页面形成知识库,方便自己使用和分享输出。

🧱 笔记结构

  • 置顶:日常习惯、健身、阅读;
  • 代码:常用代码的学习使用笔记;
  • 软件应用:常用应用、Chrome 扩展及相关教程;
  • 页面开发:页面插件和框架生成工具;
  • 网站部署:网站相关的平台、工具及知识收集;
  • Linux 服务:NAS 和服务器上的后端应用,主要以 Docker 方式部署;
  • 系统问题:Windows 系统优化和相关问题;
  • 生活区:说明书,生活记录及小技巧;
  • 博客区:聚合所有博客文章,并以分类、标签、时间轴等方式进行组合。

🍥 搭建 LearnData

  1. 进入 LearnData 项目页,点击「Use this template」,复制模板文件。

  2. 复制好后,GitHub 会自动搭建网站,架构时间约 3 分钟。

  3. 点击 Setting, 修改 Repository namexxx.github.io, xxx 是你的 GitHub 用户名。如果该项名称已被占据,GitHub Pages 无法正常显示,则查看页面底部的常见问题。

  4. 同一页面选择「Code and automation - Pages - Build and deployment - Branch」, 将 gh-page branch 设为 GitHub Pages 来源,网站运行目录默认为 /(root)。设置好后,点击「Save」。

  5. 设置成功后,页面会提示访问链接 https://xxx.github.io/,知识库搭建完毕。

    如果未出现访问链接提示或不能打开 GitHub Pages,则删除 docs/_posts 路径下的 2017-04-22-rss_feed43_feedex.md 文件,GitHub Pages 有时会对这篇旧文章里的代码报错。

🔣 配置 LearnData

LearnData 的文章页面配置查看主目录下的 samplepage.md,文本保存路径和网站配置在 docs 文件夹。

docs/.vuepress 存放网站配置文件。docs/_post 存放博客文章。docs/_temp 默认不同步到 GitHub,需手动在本地建立 _temp 文件夹,用来存放草稿。你可以按范围或功能来新建文件夹存放笔记。

docs/README.md 是默认主页,docs/blog.md 配置博客页面,docs/intro.md 是你的个人介绍。

docs/.vuepress 路径下是网站的配置文件。config.ts 配置网站环境依赖和网站属性。sidebar.ts 配置侧边栏,替换文档中文件夹路径即可,后台自动抓取路径下的 md 文件来生成侧边栏。navbar.ts 配置导航栏,推荐放你常用的文档链接。theme.ts 对主题和插件进行设置。templateBuild.html 是网页模板,调整网站关键词和第三方统计代码。配置文件上我添加了详细注释,可以自由调整,或参考 vuepress-theme-hope 配置案例

注意:LearnData 默认使用了 algolia 全文搜索,如果你没设置 Docsearch 爬虫的话,需删除 docs/.vuepress/config.ts 中 plugins 下的 docsearchPlugin 区块。删除后,站点会将页面标题和小标题作为搜索索引。

🖥️ 网站部署

LearnData 推送到 GitHub 后,会自动生成可访问的网页,但国内访问 GitHub Pages 的速度极不稳定,为了确保网站能被正常访问,必须增加国内的访问节点。

很多人选择 Gitee Pages 作为国内节点,GitHub Actions 将新文档同步到 Gitee,生成位于国内的静态页面 Gitee Pages。但是,Gitee Pages 的限制非常多,免费版无法自定义域名,必须实名验证,更别提近期的下架风波。因此,我没选 Gitee,而是把文档同步到国内服务器(域名需备案)或 Vercel。

同步到服务器

项目搭建好后,出现了红色叉叉,这是 GitHub Actions 的失败提示。这是由于 LearnData 部署了同步 ftp 代码,当正确配置服务器时,GitHub Actions 就会报错。当然,这不会影响 GitHub Pages 和 Vercel 部署。

服务器设置:进入 GitHub 仓库「setting - Secrets - Action」,添加 FTP_HOSTFTP_PORTFTP_USERNAMEFTP_PASSWORD 的密钥。配置成功后,每次修改文件,Github 都会自动推送到服务器 FTP。如果你没有服务器,也可以同步到云存储上,步骤参考 GitHub 同步到 oss

不需要服务器同步的话,可以删除 .github/workflows/main.yml 中 Sync files 区块的代码,避免每次都出红色叉叉报错。

部署到 vercel

Vercel 的速度比 GitHub Pages 来得稳定,部署步骤如下:

  1. 点击 Vercel 或将 https://vercel.com/new/clone?repository-url=https://github.com/rockbenben/LearnData/tree/gh-pages 中的 rockbenben/LearnData 改为 你的用户名/仓库名,然后会跳转至 Vercel 进行网页部署。如果你未登录的话,Vercel 会让你注册或登录,请使用 GitHub 账户进行快捷登录。

  2. 输入一个你喜欢的 Vercel 项目名称,默认 private 即可,然后点击 Create

  3. 此时 Vercel 会基于 LearnData 模板帮助你新建并初始化仓库,仓库名为你之前输入的项目名。几十秒后,满屏的烟花会庆祝你部署成功。此时点击 Go to Dashboard 可以跳转到应用的控制台。

  4. 完成前三步后网站部署好了,但此时 Vercel 页面不能对 GitHub Pages 自动同步更新。自动部署前,你需要配置 PERSONAL_TOKEN 和 GitHub Actions。

    • Creating a personal access token 建立 PERSONAL_TOKEN 个人访问令牌。
    • 将下方代码编辑到 .github/workflows/main.yml 文件底部,注意修改 dst_ownerdst_repo_name
          #将页面更新到 Vercel
          - name: Copy file to Vercel
          if: always()
          uses: andstor/copycat-action@v3
          with:
             personal_token: ${{ secrets.PERSONAL_TOKEN }}
             src_path: /.
             dst_path: /
             # 你的用户名
             dst_owner: rockbenben
             # 与 Vercel 链接的仓库名,也就是 Vercel 部署时新建的仓库
             dst_repo_name: LearnData-Vercel
             dst_branch: main
             src_branch: gh-pages
             clean: true

🤔 常见问题

网页显示异常

网站只显示文字且不能正常显示网页,这是网站路径不正确而导致的页面样式错误。

检查 docs/_posts/config.ts 中 base 的设置,默认为 /。如果 GitHub Page 提示访问链接 https://xxx.github.io/yyy,则将 base 改为 /yyy

ERR_MODULE

生成静态网页时,报错 Error [ERR_MODULE_NOT_FOUND]: Cannot find module,检查是否有第三方插件或未正确配置环境依赖。

这是 pacakge.json 引发的环境依赖报错,默认配置已经固化依赖版本号,该报错出现几率极低,遇到的话请留言到 issue 或评论区。

同步服务器报错

FTPError: 530 Login authentication failed 指 FTP 密码错误或账号不存在,需用 FileZilla 测试 FTP 的有效性。

Error: Timeout (control socket) 是同步服务器超时报错。如果出现该错误,进入 Actions 页面点击右侧按钮「Re-run all jobs」,重新进行部署。如果错误连续出现,可以尝试关闭防火墙,测试是否 GitHub 服务器被拉黑了。

静态文件名字总变

VuePress 默认使用 Vite,打包时会引入时间戳和 hash 对文件重命名,导致网站大部分的文件发生更改。即使你并没有更新文章,生成的静态文件也会改变。比如我的笔记网站用的 VuePress 默认配置,每次服务器部署需要 10 分钟,期间打开网站就会出错。

如果不想每次架构都重命名文件,可以复制「nohashname」branch。我把 nohashname 分支的打包工具换成了 Webpack,并用 chainWebpack 设置文件命名规则,避免文件非必要重命名。

本地使用 LearnData

  1. 安装环境 npm 和 pnpm,方法查看 Linux 环境部署教程
  2. 下载 LearnData 项目到本地,在目录下运行终端,输入命令 pnpm add vuepress@next vuepress-theme-hope@next @vuepress/plugin-search@next && pnpm i && pnpm up
  3. 完成前两步后,终端中输入 pnpm docs:dev,成功即可提示访问链接,默认为 http://localhost:8080/

运行本地服务器后,修改文件时预览页面也会同步发生改变。如果想停止本地服务器,在终端中按键 Ctrl + C