流水线配置(文本)
编写 pipeline.yml
pipeline.yml 是一个 格式的文件,其基本语法规则如下:
- 使用缩进表示层级关系。
- 缩进不允许使用 Ta b键,仅允许使用空格。
- 缩进空格数目不做要求,仅需相同层级的元素左侧对齐即可。
YAML 语法中的对象是一组键值对,使用冒号结构表示。
一组连字符开头的行,构成一个数组,例如:
- stage
- stage
- stage
数据结构的子成员是一个数组,则可在该项下缩进一个空格。
stages
- stage
- action
- action
- stage
- action
- action
- stage
- action
- action
一个 Stages 下包含多个 Stage,因此在编辑流水线文本时,需把 Stage 当作数组而不是对象。同理 Stage 下包含多个 Action。
Version 表示 pipeline.yml 的版本号。目前最新版本为 1.1,则配置为 version: 1.1
即可。
初始化 pipeline.yml:
Stages 由 Stage 列表组成。Stage 表示一个阶段, 其中至少存在一个 Action。Action 是流水线的最小执行单元,表示一个任务或动作。
Stages、Stage 和 Action 的关系如下所示:
# stage 和 stage 之间是串行的,即前面一个 stage 执行完毕才会开始执行下一个 stage.
# 该例子中一共有 2 个 stage.
stages:
# 在一个 stage 中,多个 Actions 是并行的,不会有依赖关系;
- stage:
# Action1-1 是 Action 的类型,不能任意填写,需要能在扩展市场中找到该类型.
- Action1-1:
...
# Action1-2 是 Action 的类型,不能任意填写,需要能在扩展市场中找到该类型.
- Action1-2:
params:
...
# 这里定义了第二个 stage,它在第一个 stage 执行结束后才会开始执行.
# 该 stage 只有一个 Action.
- stage:
# Action2-1 是 Action 的类型,不能任意填写,需要能在扩展市场中找到该类型.
- Action2-1:
params:
...
-
alias 是 Action 的别名,且不可重复。
version
Action 的版本。
params
Action 的参数,主要用于定义 Action 的行为。
每个 Action 的参数各不相同。关于 Action 更多信息,请参见 扩展市场。
resources
Action 运行资源,可配置项包括:
CPU
Mem(单位为 MB)
- git-checkout:
params:
...
resources:
cpu: 0.5
mem: 2048
Action 示例
version: "1.1"
stages:
- stage:
- git-checkout:
version: "1.0"
params:
branch: ((gittar.branch))
password: ((gittar.password))
uri: ((gittar.repo))
username: ((gittar.username))
resources:
cpu: 0.53
mem: 1024
Push 代码时将触发所有包含 on push 的 pipeline。
version: "1.1"
"on":
push:
branches:
- master
- develop
- feature/*
stages:
- stage:
- custom-script:
alias: custom-script
version: "1.0"
commands:
- echo "hello world"
从 develop 分支合并至 master 分支。
develop 中包含 on merge 的 pipeline 可触发,master 中包含 on push 的 pipeline 亦可触发。
提交合并请求将触发 check run。
check run 将查看流水线结果,若流水线运行失败则 check run 失败。