Action 配置
GitHub Actions 的配置文件叫做 workflow 文件,存放在代码仓库的 .github/workflows 目录。
workflow 文件采用 YAML 格式,文件名可以任意取,但是后缀名统一为 .yml,比如foo.yml。
一个库可以有多个 workflow 文件。GitHub 只要发现 .github/workflows 目录里面有 .yml 文件,就会自动运行该文件。
常见字段
workflow 文件的配置字段非常多。下面是一些基本字段。
name
name 字段是 workflow 的名称。如果省略该字段,默认为当前 workflow 的文件名。
name: GitHub Actions Demo
on
on 字段指定触发 workflow 的时机,通常是某些事件。
# 指定 push 事件触发 workflow。
on: push
on 字段也可以是事件的数组。
# 指定 push 事件或 pull_request 事件都可以触发 workflow。
on: [push, pull_request]
完整的事件列表,请查看官方文档。 除了代码库事件,GitHub Actions 也支持外部事件触发,或者定时运行。
on.<push|pull_request>.<tags|branches>
指定触发事件时,可以限定分支或标签。
# 指定只有 main 分支发生 push 事件时,才会触发 workflow。
on:
push:
branches:
- main
jobs
workflow 文件的主体是 jobs 字段,表示要执行的一项或多项任务。
jobs 字段里面,需要写出每一项任务的 job_id,具体名称自定义。
jobs.<job_id>.name
job_id 里面的 name 字段是任务的说明(可填可不填)。
jobs:
my_first_job:
name: My first job
my_second_job:
name: My second job
上面代码的 jobs 字段包含两项任务,job_id 分别是 my_first_job 和 my_second_job。
jobs.<job_id>.needs
needs 字段指定当前任务的依赖关系,即运行顺序。
# 这个 workflow 的运行顺序依次为: job1、job2、job3。
jobs:
job1:
job2:
needs: job1
job3:
needs: [job1, job2]
jobs.<job_id>.runs-on
runs-on 字段指定运行所需要的虚拟机环境。 它是必填字段。目前可用的虚拟机如下。
ubuntu-latest,ubuntu-18.04 或 ubuntu-16.04
windows-latest,windows-2019 或 windows-2016
macOS-latest 或 macOS-10.14
# 代码指定虚拟机环境为 ubuntu-18.04。
runs-on: ubuntu-18.04
jobs.<job_id>.steps
steps 字段指定每个 Job 的运行步骤,可以包含一个或多个步骤。每个步骤都可以指定以下三个字段。
jobs.<job_id>.steps.name: 步骤名称。jobs.<job_id>.steps.run: 该步骤运行的命令或者 action。jobs.<job_id>.steps.env: 该步骤所需的环境变量。
下面是一个完整的 workflow 文件的范例。
name: Greeting from Mona
on: push
jobs:
my-job:
name: My Job
runs-on: ubuntu-latest
steps: # steps 字段只包括一个步骤。该步骤先注入四个环境变量,然后执行一条 Bash 命令。
- name: Print a greeting
env:
MY_VAR: Hi there! My name is
FIRST_NAME: Mona
MIDDLE_NAME: The
LAST_NAME: Octocat
run: |
echo $MY_VAR $FIRST_NAME $MIDDLE_NAME $LAST_NAME.
官方文档
关于完整的工作流程语法,详见 GitHub 操作的工作流程语法