部署

下述的指南基于以下条件:

  • Markdown 源文件放置在你项目的 docs 目录;
  • 使用的是默认的构建输出目录 (.vuepress/dist) ;
  • 使用 Yarn classic部署 - 图1在新窗口打开 作为包管理器,当然也可以使用 NPM 。
  • VuePress 作为项目依赖安装,并在 package.json 中配置了如下脚本:
  1. {
  2. "scripts": {
  3. "docs:build": "vuepress build docs"
  4. }
  5. }

GitHub Pages

  1. 设置正确的 base 选项。

    如果你准备发布到 https://<USERNAME>.github.io/ ,你可以省略这一步,因为 base 默认就是 "/"

    如果你准备发布到 https://<USERNAME>.github.io/<REPO>/ ,也就是说你的仓库地址是 https://github.com/<USERNAME>/<REPO> ,则将 base 设置为 "/<REPO>/"

  2. 选项你想要使用的 CI 工具。这里我们以 GitHub Actions部署 - 图2在新窗口打开 为例。

    创建 .github/workflows/docs.yml 文件来配置工作流。

点击展开配置样例

  1. name: docs
  2. on:
  3. # 每当 push 到 main 分支时触发部署
  4. push:
  5. branches: [main]
  6. # 手动触发部署
  7. workflow_dispatch:
  8. jobs:
  9. docs:
  10. runs-on: ubuntu-latest
  11. steps:
  12. - uses: actions/checkout@v2
  13. with:
  14. # “最近更新时间” 等 git 日志相关信息,需要拉取全部提交记录
  15. fetch-depth: 0
  16. - name: Setup Node.js
  17. uses: actions/setup-node@v1
  18. with:
  19. # 选择要使用的 node 版本
  20. node-version: '14'
  21. # 缓存 node_modules
  22. - name: Cache dependencies
  23. uses: actions/cache@v2
  24. id: yarn-cache
  25. with:
  26. path: |
  27. **/node_modules
  28. key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
  29. restore-keys: |
  30. ${{ runner.os }}-yarn-
  31. # 如果缓存没有命中,安装依赖
  32. - name: Install dependencies
  33. if: steps.yarn-cache.outputs.cache-hit != 'true'
  34. run: yarn --frozen-lockfile
  35. # 运行构建脚本
  36. - name: Build VuePress site
  37. run: yarn docs:build
  38. # 查看 workflow 的文档来获取更多信息
  39. # @see https://github.com/crazy-max/ghaction-github-pages
  40. - name: Deploy to GitHub Pages
  41. uses: crazy-max/ghaction-github-pages@v2
  42. with:
  43. # 部署到 gh-pages 分支
  44. target_branch: gh-pages
  45. # 部署目录为 VuePress 的默认输出目录
  46. build_dir: docs/.vuepress/dist

提示

请参考 GitHub Pages 官方指南部署 - 图3在新窗口打开 来获取更多信息。

GitLab Pages

  1. 设置正确的 base 选项。

    如果你准备发布到 https://<USERNAME>.gitlab.io/ ,你可以省略这一步,因此 base 默认就是 "/"

    如果你准备发布到 https://<USERNAME>.gitlab.io/<REPO>/ ,也就是说你的仓库地址是 https://gitlab.com/<USERNAME>/<REPO> ,则将 base 设置为 "/<REPO>/"

  2. 创建 .gitlab-ci.yml 文件来配置 GitLab CI部署 - 图4在新窗口打开 工作流。

点击展开配置样例

  1. # 选择你要使用的 docker 镜像
  2. image: node:14-buster
  3. pages:
  4. # 每当 push 到 main 分支时触发部署
  5. only:
  6. - main
  7. # 缓存 node_modules
  8. cache:
  9. paths:
  10. - node_modules/
  11. # 安装依赖并运行构建脚本
  12. script:
  13. - yarn --frozen-lockfile
  14. - yarn docs:build --dest public
  15. artifacts:
  16. paths:
  17. - public

提示

请参考 GitLab Pages 官方指南部署 - 图5在新窗口打开 来获取更多信息。

Google Firebase

  1. 请确保你已经安装了 firebase-tools部署 - 图6在新窗口打开

  2. 在你项目的根目录下创建 firebase.json.firebaserc,并包含以下内容:

firebase.json:

  1. {
  2. "hosting": {
  3. "public": "./docs/.vuepress/dist",
  4. "ignore": []
  5. }
  6. }

.firebaserc:

  1. {
  2. "projects": {
  3. "default": "<YOUR_FIREBASE_ID>"
  4. }
  5. }
  1. 在执行了 yarn docs:buildnpm run docs:build 后, 使用 firebase deploy 指令来部署。

提示

请参考 Firebase CLI 官方指南部署 - 图7在新窗口打开 来获取更多信息。

Heroku

  1. 首先安装 Heroku CLI部署 - 图8在新窗口打开

  2. 在这里部署 - 图9在新窗口打开 注册一个 Heroku 账号;

  3. 运行 heroku login 并填写你的 Heroku 认证信息:

  1. heroku login
  1. 在你的项目根目录中,创建一个名为 static.json 的文件,并包含下述内容:

static.json:

  1. {
  2. "root": "./docs/.vuepress/dist"
  3. }

这里是你项目的配置,请参考 heroku-buildpack-static部署 - 图10在新窗口打开 来获取更多信息。

Netlify

  1. 前往 Netlify部署 - 图11在新窗口打开 ,从 GitHub 创建一个新项目,并进行如下配置:

    • Build Command: yarn docs:build
    • Publish directory: docs/.vuepress/dist
  2. 设置 Environment variables部署 - 图12在新窗口打开 来选择 Node 版本:

    • NODE_VERSION: 14
  3. 点击 deploy 按钮。

Vercel

请查看 Creating and Deploying a VuePress App with Vercel部署 - 图13在新窗口打开.

云开发 CloudBase

云开发 CloudBase部署 - 图14在新窗口打开 是一个云原生一体化的 Serverless 云平台,支持静态网站、容器等多种托管能力,并提供简便的部署工具 CloudBase Framework部署 - 图15在新窗口打开 来一键部署应用。

  1. 全局安装 CloudBase CLI :
  1. npm install -g @cloudbase/cli
  1. 在项目根目录运行以下命令一键部署 VuePress 应用,在部署之前可以先 开通环境部署 - 图16在新窗口打开
  1. cloudbase init --without-template
  2. cloudbase framework:deploy

CloudBase CLI 首先会跳转到控制台进行登录授权,然后将会交互式进行确认。

确认信息后会立即进行部署,部署完成后,可以获得一个自动 SSL,CDN 加速的网站应用,你也可以搭配使用 GitHub Action 来持续部署 GitHub 上的 VuePress 应用。

也可以使用 cloudbase init --template vuepress 快速创建和部署一个新的 VuePress 应用。

提示

更多详细信息请查看 CloudBase Framework 的部署项目示例部署 - 图17在新窗口打开

21 云盒子

请查看 21 云盒子 - 部署一个 VuePress 静态网页部署 - 图18在新窗口打开