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

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

  •  
  •   1874w ·
    LetTTGACO · 167 天前 · 1760 次点击
    这是一个创建于 167 天前的主题,其中的信息可能已经有所发展或是发生改变。

    语雀 + 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 临时域名,你也可以绑定自己的域名。 image

    自动化同步&部署

    检查 Github Actions 权限

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

    配置环境变量

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

    自动化部署

    当在语雀中改动文档后,手动/自动触发 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

    第 1 条附言  ·  164 天前
    语雀账号密码模式回归!

    之前语雀将 Web 版本的语雀账号密码模式增加了人机校验,导致 Elog 无法登录,现已改成伪装成手机端登录,测试可行

    所以目前该模板仓库支持:
    语雀 Token 模式(需要语雀超级会员)和账号密码模式(不需要任何会员)两种方式,默认为账号密码模式,如果需要切换为 Token 模式,则修改 elog.config.js 文件中的 platform 为 yuque 即可
    3 条回复    2023-11-19 11:20:32 +08:00
    ob
        1
    ob  
       167 天前
    强啊,能带搜索功能吗?
    1874w
        2
    1874w  
    OP
       167 天前   ❤️ 1
    @ob vitepress 感谢提醒
    根据 vitepress 提供的文档,可以设置本地搜索,我已经添加到模版仓库
    https://vitepress.dev/reference/default-theme-search#local-search
    1044523901
        3
    1044523901  
       167 天前
    不错 刚好想将 yuque 转出来~
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   2544 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 28ms · UTC 12:42 · PVG 20:42 · LAX 05:42 · JFK 08:42
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.