先决条件
- 拥有GitHub账号
 - 创建了USERNAME.github.io的仓库,USERNAME为你的GitHub用户名
 - 系统中安装了Git
 - 安装了Node.js
 
初始化
安装hexo
1  | npm install -g hexo-cli  | 
如果安装失败,可以尝试使用cnpm
1  | npm install -g cnpm --registry=https://registry.npm.taobao.org  | 
初始化hexo
1  | mkdir hexo_blog && cd hexo_blog  | 
编写博客文章
1  | # 进入hexo_blog目录后  | 
然后会在hexo_blog/source/_posts目录下生成一个some-title.md文件,编辑该文件即可。
生成博客页面
1  | # 进入hexo_blog目录后  | 
部署到github
reference: https://hexo.io/zh-cn/docs/github-pages
配置GitHub Actions
创建.github/workflows/pages.yml文件,内容参考如下,主要是注意修改node-version,确保它与你本地的node版本一致:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50name: Pages
on:
push:
branches:
- main # default branch
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
token: ${{ secrets.GITHUB_TOKEN }}
# If your repository depends on submodule, please see: https://github.com/actions/checkout
submodules: recursive
- name: Use Node.js 20
uses: actions/setup-node@v4
with:
# Examples: 20, 18.19, >=16.20.2, lts/Iron, lts/Hydrogen, *, latest, current, node
# Ref: https://github.com/actions/setup-node#supported-version-syntax
node-version: "20"
- name: Cache NPM dependencies
uses: actions/cache@v4
with:
path: node_modules
key: ${{ runner.OS }}-npm-cache
restore-keys: |
${{ runner.OS }}-npm-cache
- name: Install Dependencies
run: npm install
- name: Build
run: npm run build
- name: Upload Pages artifact
uses: actions/upload-pages-artifact@v3
with:
path: ./public
deploy:
needs: build
permissions:
pages: write
id-token: write
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4推送hexo_blog目录下的所有文件到main分支
使用命令行工具
- 先安装hexo-deployer-git
 
1  | # 进入hexo_blog目录后  | 
- 配置部署仓库
 
配置文件为hexo_blog/_config.yml,找到deploy部分,修改为:
1  | deploy:  | 
将USERNMAE替换为你的GitHub用户名。
- 部署
 
1  | # 进入hexo_blog目录后  | 
后续的日常工作
维护博客内容
1  | hexo clean # 清除缓存  | 
部署博客
- 如果是使用命令行工具,执行
hexo deploy即可 - 如果是使用GitHub Actions,执行
git commit && git push即可