方案比较

之前的部署方案是服务器本地保存源文件,写入新内容时使用vscode的远程ssh编辑,然后git推送到github仓库作为备份。有一点问题就是服务器硬件来自阿里云的轻量应用服务器,对硬盘的iops有限制,进行大量读写操作时候一旦超过就会引发系统死机。以及稀烂的CPU和内存资源,随着源文件越来越大,生成时间也越来越长。这个时候github推出了action功能,允许我直接在github的服务器上进行生成操作,而且速度掉打阿里云服务器。所以方案改成这样,直接使用github保存源代码,每次提交代码之后自动进行生成操作,同时将生成的静态文件直接复制到服务器的网站服务目录内。同时也简化了另一个问题,就是多用户编辑,之前需要服务器上多个用户的读写权限,现在只需要github仓库添加作者就可以了。

hexo部署推送

本来是应该用hexo的git部署的,然后没配置明白hexo部署action的ssh密钥登录,反正这段用不到了,已经换成直接复制了

也就是执行hexo d之后将生成的代码通过git推送到自己的远程服务器,这部分内容我在2022年写过,因为当时的方案是本地编辑生成然后git推送到服务器,和现在一样,直接参考这篇文章

github action配置

github开了一个新的仓库保存源代码,上传现有内容之后,准备新建action。GitHub Actions的配置文件叫做workflow文件,存放在源代码仓库的.github/workflows目录。GitHub在我们完成预设触发条件时,只要发现.github/workflows目录里面有.yml文件,就会自动读取运行该文件。

编辑workflow

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
50
51
52
53
54
55
56
57
name: Blog CI/CD

on:
push:
branches: [main] # 当监测 main,master 的 push
paths: # 监测文件变动限制
- '*.json'
- '**.yml'
- '**.md'
- '**/source/**'

jobs:
blog: # 任务名称
timeout-minutes: 10 # 设置 10 分钟超时
runs-on: ubuntu-latest # 指定最新 ubuntu 系统
steps:
- uses: actions/checkout@v2 # 拉取仓库代码
- uses: actions/setup-node@v2 # 设置 node.js 环境
- name: Cache node_modules # 缓存 node_modules,提高编译速度,毕竟每月只有 2000 分钟。
uses: actions/cache@v2
env:
cache-name: cache-node-modules
with:
path: ~/.npm
key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }}
restore-keys: |
${{ runner.os }}-build-${{ env.cache-name }}-
${{ runner.os }}-build-
${{ runner.os }}-
- name: Init Node.js # 安装源代码所需插件
run: |
npm install
echo "init node successful"
- name: Install Hexo-cli # 安装 Hexo
run: |
npm install -g hexo-cli --save
echo "install hexo successful"
- name: Build # 编译创建静态博客文件
run: |
hexo clean
hexo g
echo "build blog successful"
- name: Deploy # 设置 git 信息并推送静态博客文件
uses: easingthemes/ssh-deploy@v2.1.1
env:
# 私钥id_rsa,存在secrets的PRIVATE_KEY中
SSH_PRIVATE_KEY: ${{ secrets.PRIVATE_KEY }}
# 复制操作参数,"-avzr --delete"部署时清空服务器目标目录下的文件
ARGS: "-avzr --delete"
# 源目录,相对于$GITHUB_WORKSPACE根目录的路径
SOURCE: "public/"
REMOTE_HOST: "www.triority.cc"
REMOTE_USER: "root"
# 目标目录
TARGET: "/blog_public"

- run: echo "Deploy Successful!"

然后在仓库设置密钥PRIVATE_KEY值为ssh私钥文件即可