最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    正文概述 掘金(饼饼饼)   2021-03-08   935

    介绍

    用官方的话来说 VuePress 是一款以 Vue 驱动的静态网站生成器,它的诞生初衷是为了支持 Vue 及其子项目的文档需求。由于vuepress支持自定义开发主题所以很多人拿它来写博客,下面我会用 VuePress 搭建一个极简的博客网站并使用GitHub Actions部署到GitHub Pages。

    示例项目github源码

    示例博客访问地址

    搭建博客

    1. 创建并进入一个新目录
    mkdir vuepress-starter && cd vuepress-starter
    
    1. 使用你喜欢的包管理器进行初始化
    yarn init # npm init
    
    1. 将 VuePress 安装为本地依赖
    yarn add -D vuepress # npm install -D vuepress
    
    1. 创建你的第一篇文档
    mkdir docs && echo '# Hello VuePress' > docs/README.md 
    
    1. 在 package.json 中添加一些 scripts
    {
      "scripts": {
        "docs:dev": "vuepress dev docs",
        "docs:build": "vuepress build docs"
      }
    }
    
    1. 在本地启动服务器
    yarn docs:dev # npm run docs:dev
    

    VuePress 会在 http://localhost:8080 启动一个热重载的开发服务器。 基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions 如果出现文章乱码可以参照这篇文章去解决。

    现在,你应该已经有了一个简单可用的 VuePress 文档。如果你有兴趣的话可以去 VuePress 官方网站上深入学习它的配置和用法来丰富你的网站内容。

    部署

    部署到 GitHub Pages

    接下来的内容假设你已经使用过GitHub,并且对GitHub Pages有一定的了解。

    1. 在GitHub上创建一个仓库

    基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    1. 在 docs/.vuepress/config.js 中设置正确的 base

    在 docs/.vuepress 文件夹下创建 config.js

    // config.js
    module.exports = {
        base: "/vuepress-starter/"
    }
    
    1. 配置.sh脚本

    在你的项目根目录中,创建一个如下的 deploy.sh 文件(请自行判断去掉高亮行的注释):

    #!/usr/bin/env sh
    
    # 确保脚本抛出遇到的错误
    set -e
    
    # 生成静态文件
    npm run docs:build
    
    # 进入生成的文件夹
    cd docs/.vuepress/dist
    
    # 如果是发布到自定义域名
    # echo 'www.example.com' > CNAME
    
    git init
    git add .
    git commit -m 'deploy'
    
    # 如果发布到 https://<USERNAME>.github.io
    # git push -f git@github.com:<USERNAME>/<USERNAME>.github.io.git main
    
    # 如果发布到 https://<USERNAME>.github.io/<REPO>
    git remote add origin git@github.com:huabingtao/vuepress-starter.git
    git branch -M main
    git push -f git@github.com:huabingtao/vuepress-starter.git main:gh-pages
    
    cd -
    
    1. 用sh脚本部署

    打开package.json下新增一条命令

    "scripts": {
      ...,
      "deploy": "bash deploy.sh"
    }
    

    打开控制台执行

    npm run deploy
    
    1. 设置仓库GitHub Pages访问路径

    现在代码已经推送到远程仓库的gh-pages分支下,接下来我们需要设置博客的访问路径,点击右上角的Settings按钮进入设置。 基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions 选择目标分支为gh-pages,根目录为root 基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions 稍等几分钟后访问huabingtao.github.io/vuepress-st…此时发现我们的博客已经部署到Github Pages了。 到这里如果你只是希望你的博客可以随时在互联网被访问到,只需要在写完文章之后去执行 npm run deploy 这行命令就可以了。

    使用 Github Actions 自动部署

    现在我们写一篇文章并且发布到 GitHub Pags 需要手动执行sh脚本,使用GitHub Actions 可以帮助我们简化流程,让写完一篇文章后只需要将代码上传至 GitHub 就能帮我们自动构建部署到线上。

    GitHub Actions 有一些自己的术语。

    1.workflow (工作流程):持续集成一次运行的过程,就是一个 workflow。

    2.job (任务):一个 workflow 由一个或多个 jobs 构成,含义是一次持续集成的运行,可以完成多个任务。

    3.step(步骤):每个 job 由多个 step 构成,一步步完成。

    4.action (动作):每个 step 可以依次执行一个或多个命令(action)。

    想要了解更多Github Actions知识可以浏览官方GitHub Actions快速入门,或者阮一峰老师的GitHub Actions 入门教程

    创建个人访问令牌

    1. 在任何页面的右上角,单击您的个人资料照片,然后单击 Settings(设置)

    基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    1. 在左侧边栏中,单击 Developer settings。

    基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    1. 在左侧边栏中,单击 Personal access tokens(个人访问令牌)

    基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    1. 单击 Generate new token(生成新令牌)。

    2. 给令牌一个描述性名称。

    令牌名字一定要叫:ACCESS_TOKEN

    1. 选择要授予此令牌的作用域或权限。 要使用令牌从命令行访问仓库,请选择 repo(仓库)。

    基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    1. 单击 Generate token(生成令牌)。
    2. 单击复制将令牌复制到剪贴板。 出于安全原因,离开此页面后,您将无法再次看到令牌。

    编写 workflow 文件

    工作流文件使用 YAML 语法,这里不对 YAML 语法做过多介绍想要了解更多信息请参阅五分钟了解 YAML。

    接着创建.github/workflows/main.yml文件,内容如下:

    name: docs
    
    on:
      # 每当 push 到 main 分支时触发部署
      push:
        branches: [main]
      # 手动触发部署
      workflow_dispatch:
    
    jobs:
      docs:
        runs-on: ubuntu-latest
    
        steps:
          - uses: actions/checkout@v2
            with:
              # “最近更新时间” 等 git 日志相关信息,需要拉取全部提交记录
              fetch-depth: 0
    
          - name: Setup Node.js
            uses: actions/setup-node@v1
            with:
              # 选择要使用的 node 版本
              node-version: "14"
    
          # 缓存 node_modules
          - name: Cache dependencies
            uses: actions/cache@v2
            id: yarn-cache
            with:
              path: |
                **/node_modules
              key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
              restore-keys: |
                ${{ runner.os }}-yarn-
    
          # 如果缓存没有命中,安装依赖
          - name: Install dependencies
            if: steps.yarn-cache.outputs.cache-hit != 'true'
            run: yarn
    
          # 运行构建脚本
          - name: Build VuePress site
            run: yarn docs:build
    
          # 查看 workflow 的文档来获取更多信息
          # @see https://github.com/crazy-max/ghaction-github-pages
          - name: Deploy to GitHub Pages
            uses: JamesIves/github-pages-deploy-action@3.7.1
            with:
              ACCESS_TOKEN: ${{ secrets.ACCESS_TOKEN }}
              # 部署到 gh-pages 分支
              BRANCH: gh-pages
              # 部署目录为 VuePress 的默认输出目录
              FOLDER: docs/.vuepress/dist
    
    

    以上代码主要配置内容如下:

    1. branches 代表git push 触发flow的分支名称,如果你的分支不是main请修改正确。
    2. run 表示运行命令,若没有修改的话就是 yarn docs:build
    3. ACCESS_TOKEN 读取GitHub仓库之前我们设置的 ACCESS_TOKEN,名称一定要与之前设置的相同。
    4. BRANCH 部署到 gh-pages 分支下。
    5. FOLDER 部署目录,如果没有修改默认配置就是 docs/.vuepress/dist

    完成以上配置,下次push代码的时候,就会自动开启构建。

    尝试push代码,回到GitHub上点击actions,发现项目已经在自动构建了。

    基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    点击进入查看部署情况。

    基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    部署成功,如果构建失败GitHub会发送一封邮件到你的邮箱。

    搭建过程中遇到的问题

    1. 如果你打算发布到 https://<USERNAME>.github.io/, 则不需要配置 .vuepress/config.js base 属性,因为 base 默认是 "/"。
    2. 发布到线上后发现css样式丢失,经查看发现访问路径发生404的有可能是项目引用路径错误,本文没有修改过打包路径,用的是默认路径 docs/.vuepress/dist,如不一致请修改。
    3. 本文所使用的actions版本是v3,以往教程中所讲到的使用的是JamesIves/github-pages-deploy-action v2版本,新版本语法已经发生了变化,如果继续使用就会发生错误。
    4. ACCESS_TOKEN 一定要和github上的sectets上的名称相同。

    参考资料

    • vuepress官网
    • 使用 GitHub Actions 自动部署博客
    • 阮一峰 GitHub Actions 入门教程
    • MarkDown 基本语法

    小结

    本文介绍了如何使用 vuepress 搭建博客,并使用GitHub Pages 部署到线上环境,但是部署的流程都是手动操作的有些麻烦,文章后半部分内容简单介绍了GitHub Actions,实现了当我们要发布一篇文章的时候只要pushGitHub 就能实现自动化打包发布流程,让双手从机械的流程中解脱专注于写作。虽然能够简单实现一个博客网站,但是 VuePress 的更有趣的玩法还有待大家自己去学习。

    以上就是本篇文章的所有内容。最后,感谢您阅读这篇文章,有任何问题或反馈请给我留言。


    起源地下载网 » 基于 vuepress 搭建博客教程 + 自动化部署 GitHub Actions

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元