github-action
Create by fall on 29 Jul 2025
Recently revised in 29 Jul 2025
GitHub Action
CICD 工具的一种,可以帮助你进行一些固定的繁琐操作
- CI ** 的全称是Continuous Integration**,直译为可持续集成,而普遍对其的解释是频繁地(一天多次)将代码集成到主干。对于这个解释我们要搞懂其中的两个概念:
- CD:持续交付(Continuous delivery) 或者 持续部署(continuous deployment) 或者是两者的并集,
- CI/CD 既可能仅指持续集成和持续交付构成的关联环节,也可以指持续集成、持续交付和持续部署这三项构成的关联环节。更为复杂的是,有时"持续交付"也包含了持续部署流程。
我以我自己的工作流为例,解释
name: deploy docs
# 指定在什么情况下会运行
on:
# 在指定的分支发生变化的时候运行
push:
branches:
- source
paths:
- ".github/workflows/deploy-docs.yml"
- "my-docs/**"
- "docusaurus.config.ts"
- "src/**"
- "package.json"
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# 部署到 GitHub Pages 时 GITHUB_TOKEN 的权限
permissions:
contents: write
# 只能同时执行一个部署,跳过正在运行的队列Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# 然而,不要取消正在进行的脚本,当我们想要生成内容部署时。
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
# Build job
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
ref: source
- name: Setup Node
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install pnpm
run: npm i -g pnpm
- name: Install dependencies
run: pnpm i --frozen-lockfile
- name: Build doc
run: pnpm build
- name: Deploy Doc 🚀
uses: JamesIves/github-pages-deploy-action@v4
with:
branch: github-pages
folder: ./build
clean: false
- name: Deploy Doc 🚀
uses: actions/upload-pages-artifact@v3
with:
path: build
# Deployment job
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
needs: build
permissions:
pages: write
id-token: write
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4