通过Github Action自动化部署静态文件在COS存储桶

如果您有自动化部署 VuePress/dumi/Astro 等文档站或者是 Hexo 等静态个人博客的需求,您可能需要 Github Action 的帮助。如果你部署在Vercel上,Vercel会全自动完成所有配置操作,只需提交项目源文件即可,无需按照此教程配置工作流文件。

本篇教程建立在你有将静态网站全自动部署在腾讯云COS的需求。

本教程将以部署 Astro站点 为例向你演示如何编写Workflow File,不同框架的指令/Node版本可能不同,请以实际为准。

准备项目源文件

首先,你需要在Github上创建一个空仓库,创建后将项目源文件提交到仓库中。提交后,你需要确保仓库中包含构建dist的必要文件。例如 srcpackage.json

创建Workflow File

新仓库正常情况下不会有 .github 目录,这时候你可以手动创建 .github/workflows 文件夹。创建后在此文件夹内创建一个yml文件,这个文件就是你的Action工作流配置文件,我们将在这个文件中配置Action。

比如,我们创建一个 push-online.yml 文件,用于将构建后的dist上传到COS存储桶中

配置yml

基础配置

首先,我们要对工作流进行命名,还要设置对应的分支(同时可以配置运行时忽略的文件/目录)。

name: BuildOnCOS  # 将工作流命名为“BuildOnCOS”
on:
  push:
    branches:
      - master  # 提取master分支下的文件
    paths-ignore:  # 忽略的文件/文件夹列表
      - README.md
      - LICENSE
      - .github/*
      - .gitattributes

最好不要使用中文命名,否则可能会出现部分问题。

运行环境配置

得益于Github的强大配置,我们可以在上面运行Ubuntu虚拟机以及各种虚拟环境。在这个示例中我们使用 Ubuntu&Node.JS 环境进行build和upload。

  • node-version:设置Node版本,可以是latest最新版也可以指定版本号。

  • cache:包管理器选择,用于缓存依赖,默认情况下是 npm

  • cache-dependency-path:你的包管理文件名,通常情况下是 package.json

  • run:安装依赖指令,通常情况下是 包管理器+install

jobs:
  PushToCOS:
    runs-on: ubuntu-latest  # 设置运行环境,这里是Ubuntu的最新镜像
    steps:
      - name: Checkout Branch  # 建议设置分支检查,以免出现问题
        uses: actions/checkout@v4
        with:
          ref: master  # 这里的分支和“基础配置”中的分支一致
      - name: Setup node
        uses: actions/setup-node@v4  # 初始化Node环境
        with:
          node-version: 20  # 可以自选Node版本,详情参阅官方文档
          check-latest: false  # 建议false
          cache: 'npm'  # 选择包管理器,默认是npm
          cache-dependency-path: package.json  # 你的包管理文件名,默认情况下不需要更改
      - name: Install Packages
        run: npm install  # 安装依赖文件,否则无法构建静态文件
      - name: Build project
        run: npm run build

如果试运行通过,可以进行最后一步配置文件上传到COS存储桶的步骤。

COS配置

首先,感谢zkqiang的贡献,提供了在Action上上传文件到TencentCOS的程式。

  • args:COS命令,可参考TencentCOSCLI文档

  • secret_id&secret_key:RAM账户密钥,在“控制台-访问管理”配置。建议新建一个专用RAM账户用于Action。这些字符切忌不要直接写在yml中,在仓库的环境值中配置。

  • bucket:存储桶名称,建议在环境值中配置。

  • region:存储桶ap地域,复制完整。

      - name: Upload COS
        uses: zkqiang/tencent-cos-action@v0.1.0
        with:
          args: upload -r ./dist/ /client  # 构建后的文件目录
          secret_id: ${{ secrets.SECRET_ID }}  # 这些密钥将在Github仓库环境值中配置
          secret_key: ${{ secrets.SECRET_KEY }}
          bucket: ${{ secrets.BUCKET }}
          region: ap-hongkong  # 你的COS存储桶地域,复制完整ap到此处

环境值配置

完成yml的配置,我们需要写入环境值以替换Workflow File中的 ${{ secrets.XXXXXXX }} 字样。配置环境值可以保护您的数据安全,以防被不法分子替换COS文件。

点击仓库的“setting”,进入设置页面。在设置菜单中选择“Secrets and variables”,并在二级菜单中选择“Actions”。在“Repository secrets”中点击右侧绿色按钮“New repository secret”即可创建一个仓库环境值。

在新页面中,输入相应的Name和Secret并单击“Add secret”以完成配置这个变量。

我们需要配置的Secret:

  • BUCKET:存储桶名称(如下图)

  • SECRET_ID:子账户操作ID

  • SECRET_KEY:子账户操作密钥

提交变量之后,您的Action理应自动运行并会把构建后的dist文件上传到COS桶中。这些操作是即时生效的。流程大概在1分钟之内,除非你的依赖非常非常多。


通过Github Action自动化部署静态文件在COS存储桶
https://www.mengxiblog.top//archives/use-github-action-build-oncosbucket
作者
MengXi
发布于
2024年09月16日
更新于
2024年12月14日
许可协议