本文首发于我的博客:jiangyixiong.top
Hexo是一款快速,简洁且高效的博客框架。可以快速地将Markdown格式文章转化为静态博客页面。Hexo本身附带一键部署功能,可将生成的静态页面部署至GitHub pages,但本文讨论的是另一种部署方式。通过Github Actions在提交博客源码时自动生成静态页面并部署至Github Pages。
Github Pages 被设计用以发布存储于Github仓库的个人、组织、项目相关的静态页面。
Github Pages 的配置非常方便,我们只需将静态页面上传至一个Github仓库,并在仓库配置中开启GithubPages相关选项
其中在Source部分中配置静态页面所在的分支与目录。设置完成后即可通过{UserName}.github.io访问。这里也可以使用自定义域名,详细配置见Github官方指南。
Github Actions是Github推出的自动构建、测试、部署的工作流。类似于Gitlab的CI/CD或Jenkins。可以通过Github的pull、merge、issue等动作触发。
有了Github Pages,我们只需要将Hexo生成的静态页面推送至我们配置了Github Pages对应的仓库即可。如果我们采用手动操作,有如下几个步骤:
而采用Github Actions,我们仅需将这几个动作写成脚本,自动化即可。
这部分不详细说明Hexo的使用,可见Hexo官方指南,非常详细且有中文。
$ npm install -g hexo-cli
$ hexo init <目录名>
$ cd <目录名>
$ npm install
之后我们可以添加几篇初始内容。
$ hexo new "文章标题"
$ hexo new page --path about/me "页面标题"
之后,我们本地运行Hexo查看下效果。
$ hexo server
至此,我们已经在本地完成了Hexo的初始化。之后将其推送至一个新的Github仓库,作为源码仓库。
重点来了,之后我们要配置Github Actions,让源码仓库在有新的push内容时,自动生成静态页面,并将静态页面推送至Github Pages仓库。
首先,为了让Actions拥有向Pages仓库push内容的权限,我们需要在我们的Github账号中新建一个Personal Access Token。前往个人Settings - Developer settings - Personal access token。并创建一个新的Token。
之后,我们需要将这个新创建的token添加至博客源码仓库。前往源码仓库的设置页面:Settings-Secret, 添加一个新的 repository secret。
完成之后我们就可以开始编写Actions脚本了。添加Action的方法为,在源码仓库中,新建 .github/workflows
目录。并在其中创建一个yml
文件,文件名可自由定义。这个yml
文件就是自动构建的脚本,具体的编写可见Github官方指南。这里放出本博客的构建脚本并进行说明:
name: Garys blog deployment #自动构建工作流名称
on:
push:
branches:
- "master"
#触发器,详见https://docs.github.com/en/actions/reference/workflow-syntax-for-github-actions#onpushpull_requestpaths
jobs: # 构建任务列表,一个工作流中可有多个构建任务
generate_public: # 构建任务1
name: generate & deploy
runs-on: ubuntu-latest # 定义运行环境,这里选择ubuntu
steps: # 任务步骤列表,本任务中有4项任务
# 1. 将本仓库代码拉至当前工作目录,这里使用了Github提供的预定义Action,可在 https://github.com/actions/checkout 查看其源码,本质上是通过git拉取当前仓库指定分支的代码。
- name: Checkout
uses: actions/[email protected]
with:
persist-credentials: false
# 2. 通过npm安装项目依赖,这里直接通过run运行npm命令
- name: Setup Hexo
run: |
npm install
# 3. 通过npm生成hexo静态页面
- name: Generate
run: |
npm run-script build
# 4. 将生成的静态页面目录推送至Github pages仓库。这里使用了Github pages部署action,源码与文档见 https://github.com/JamesIves/github-pages-deploy-action ,其通过Git将指定目录推送至指定仓库。
- name: Deploy
uses: JamesIves/github-pages-deploy-[email protected]
with:
GITHUB_TOKEN: ${{ secrets.BLOG_DEPLOYMENT }} # 刚才配置的Repository secret,secrets后的名称与刚才配置的名称一致。
BRANCH: master # 目标分支
FOLDER: public # 静态页面所在当前残酷的目录
REPOSITORY_NAME: GaryXiongxiong/Myblog # 目标仓库
GIT_CONFIG_NAME: GaryXiongxiong
GIT_CONFIG_EMAIL: [email protected]
CLEAN: true
配置完成后,只需把我们更新后的源码仓库推送至Github,之后便可在Github仓库页面的Actions标签中查看构建日志:
构建成功后,我们便可通过我们Github pages的链接查看更新后的博客啦!