1. 什么是 GitHub Actions 与 workflow ?
GitHub Actions 是 GitHub 提供的一种持续集成(CI)和持续部署(CD)的工具,用于自动化软件开发过程中的各种任务和工作流。GitHub Action Workflow 是一组定义在存储库中的自动化任务,可以根据不同的事件(例如代码推送、拉取请求、问题创建等)触发执行。
每个 GitHub Action Workflow 都是由一个或多个步骤(Steps)组成,每个步骤可以包含一个或多个命令、脚本或操作。这些步骤可以按顺序执行,也可以并行执行,以便自动化构建、测试、部署等任务。
一些常见的用途包括:
- 自动测试和构建: 在代码推送到存储库时自动运行测试,确保代码的质量和稳定性。
- 自动部署: 当代码合并到主分支时,自动将应用程序部署到生产环境。
- 发布通知: 在新问题创建或拉取请求时,自动发送通知到团队成员。
- 自动化文档生成: 在代码变更时,自动生成更新的文档。
- 版本发布: 在发布新版本时,自动执行一系列步骤,如创建标签、生成发布文件等。
- 代码质量检查: 自动运行代码风格检查、静态分析等工具,以确保代码符合规范。
- 容器构建: 自动构建 Docker 镜像并将其推送到容器注册表。
- 多环境支持: 根据不同分支或标签,自动执行适合的工作流程,以支持不同的开发、测试和生产环境。
GitHub Action Workflow 使用 YAML 文件来定义,该文件位于存储库中的 .github/workflows
目录下。这些定义可以根据项目的需求进行配置和自定义。
2. 代码实战
2.1 以MSVS工程(C++工程)为例
# 定义构建流程 name: Build Process # 当代码被推送到存储库时触发工作流 on: push jobs: # 定义构建作业 build: # 在 Windows 环境中运行 runs-on: windows-latest steps: # 步骤:检出代码 - name: Checkout code uses: actions/checkout@v3 # 步骤:设置 MSBuild - name: Setup MSBuild uses: microsoft/setup-msbuild@v1.1 # 步骤:构建 VS 项目 - name: Build VS Project run: | # 运行生成 DLL 的命令 msbuild project.sln /p:Configuration=Release /p:Platform=x64 # 步骤:上传 ZIP 构件 - name: Upload ZIP Artifact uses: actions/upload-artifact@v3 with: name: project # 压缩包过期时间 retention-days: 90 # 压缩包路径,需要根据自己项目配置进行相对应的设置 path: | release
2.2 以Maven项目(Java项目)为例
# 定义构建流程 name: Build Process # 当代码被推送到存储库时触发工作流 on: push jobs: # 定义构建作业 build: # 在 Ubuntu 环境中运行 runs-on: ubuntu-latest steps: # 步骤:检出代码 - name: Checkout code uses: actions/checkout@v3 # 步骤:设置 Java 环境为 JDK 8,并使用 Corretto 发行版,缓存 Maven - name: Setup Java uses: actions/setup-java@v3 with: java-version: '8' distribution: 'corretto' cache: 'maven' # 步骤:构建 Maven 项目 - name: Build Maven Project run: | # 运行打包 Maven 项目的命令 mvn -DskipTests package # 步骤:上传 ZIP 构件 - name: Upload ZIP Artifact uses: actions/upload-artifact@v3 with: name: project retention-days: 90 path: | target/*
3. 如何找到GitHub Actions
3.1 找到你的GitHub仓库
3.2 提交你的workflow文件
在项目根路径建立/.github/workflows文件夹,并在这个路径下放置你的yaml构建脚本
3.3 等待GitHub Actions构建完成
4. Actions MarketPlace
如果你对于一些不会写的构建过程,你可以到Actions MarketPlace
找到对应的构建脚本并直接使用。
https://github.com/marketplace?type=actions
附录
官方中文GitHub Actions文档
https://docs.github.com/zh/actions