[Elog 最佳实践] 语雀 + Elog + VitePress + GitHub Actions + Vercel 文档站点解决方案

309 天前
 1874w

语雀 + Elog + VitePress + GitHub Actions + Vercel 文档站点解决方案

前言

注意:2023/11/18 更新:由于语雀官方更新了账号密码登录规则,加上了人机校验,账号密码模式已无法通过 Elog 登录!目前只能使用 Token 方式同步文档(需要语雀超级会员)
如果你不是语雀超级会员,可以使用 Notion 进行部署文档站点,参考示例

VitePress 要求 Node 18 及以上版本

文档站点工具汇总

博客搭建指南

Fork 模板仓库

点击 Fork 该模板仓库到个人 Github 账号仓库下并 clone 到本地

安装依赖

在项目根目录下运行命令安装依赖

npm install

新建本地调试文件

在项目根目录中复制.elog.example.env文件并改名为.elog.env,此文件将用于本地同步文档时使用

配置语雀

参考示例知识库 ,选择或新建语雀文档知识库,并按照文档提示 配置语雀并获取 token login repo。并在本地.elog.env中写入

YUQUE_TOKEN=获取的 Token
YUQUE_LOGIN=获取的 login
YUQUE_REPO=获取的 repo

本地调试

在项目根目录运行同步命令

npm run elog:sync-local

配置 VitePress

根据 VitePress 文档,配置你的文档站点直到你满意为止。

  1. 修改 VitePress 的配置文件docs/.vitepress/config.mts中的导航栏、路由信息等
  2. 修改首页信息docs/index.md中的文字和路由
  3. 更多自定义配置请看 VitePress 文档

本文档默认是按照文档目录渲染站点 URL ,可能会存在中文路由,如果想要短路由模式,即站点路由全英文,可前往进阶配置 中阅读

启动 VitePress

在项目根目录运行 VitePress 启动命令,打开本地链接

npm run docs:dev

提交代码到 github

本地访问没问题直接提交所有文件到 Github 仓库即可

部署到 Vercel

注册 Vercel 账号并绑定 Github ,在 Vercel 导入 该项目,Vercel 会自动识别出该 VitePress 项目,不需要改动,直接选择 Deploy 部署。部署完成会有一个 Vercel 临时域名,你也可以绑定自己的域名。

自动化同步&部署

检查 Github Actions 权限

在 Github 仓库的设置中找到 Actions-General,打开流水线写入权限Workflow permissions

配置环境变量

在本地运行时,用的是.elog.env文件中定义的语雀账号信息,而在 Github Actions 时,需要提前配置环境变量。
在 Github 仓库的设置中找到 Secrets and variables,新增仓库的环境变量和.elog.env保持一致即可

自动化部署

当在语雀中改动文档后,手动/自动触发 Github Actions 流水线,会重新从语雀增量拉取文档,自动提交代码到 Github 仓库。
Vercel 会实时监测仓库代码,当有新的提交时都会重新部署博客。如此就实现了自动化部署博客。
整个流程的关键点就在于:如何手动/自动触发 Github Actions 。
在项目.github/workflows/sync.yaml中已经配置了外部 API 触发 Github Actions 事件,所以只需要调用 API 触发流水线即可。

手动触发

为了方便,这里提供一个部署在 Vercel 的免费公用的ServerlessAPI,按照文档配置好 URL 参数并浏览器访问即可触发流水线

https://serverless-api-elog.vercel.app/api/github?user=xxx&repo=xxx&event_type=deploy&token=xxx

自动触发-语雀 webhooks

在语雀知识库 - 更多设置 - 消息推送中可配置语雀 webhooks ,填写上面的 Vercel Serverless API 。当文档更新时,语雀会调用这个 API 进行推送,进而触发 Github Actions

注意:语雀是国内文档平台,调用国外 Vercel 的服务可能会失败,可自行部署 API

注意:知识库配置了「自动发布」功能后,文档的 更新/发布 操作暂不会发送 webhooks

参考示例

示例 Github 仓库:https://github.com/elog-x/yuque-vitepress
示例语雀知识库:https://www.yuque.com/1874w/yuque-vitepress-template
示例文档站点:https://yuque-vitepress.vercel.app

Elog

Elog Github: https://github.com/LetTTGACO/elog

Elog 文档: https://elog.1874.cool

1929 次点击
所在节点    分享创造
3 条回复
ob
308 天前
强啊,能带搜索功能吗?
1874w
308 天前
@ob vitepress 感谢提醒
根据 vitepress 提供的文档,可以设置本地搜索,我已经添加到模版仓库
https://vitepress.dev/reference/default-theme-search#local-search
1044523901
308 天前
不错 刚好想将 yuque 转出来~

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/993153

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX