deployment - Travis CI:如何有条件地运行提供者部署作业?
问题描述
我有一个基于 2 个条件部署到不同 S3 存储桶的 travis 脚本:1. 分支名称 2. $TRAVIS_BRANCH
env 变量
... travis stuff
deploy:
- provider: s3
... other config
bucket: my-staging-bucket
on:
repo: MyOrg/my-repo
branch: staging
condition: $TRAVIS_BRANCH = staging
- provider: s3
... other config
bucket: my-prod-bucket
on:
repo: MyOrg/my-repo
branch: production
condition: $TRAVIS_BRANCH = production
它按预期工作:当我部署到登台时,第一个配置成功构建和部署,并且我在 Travis 的工作日志中获得了适当的消息。
它还尝试部署到生产环境并被on:
条件阻止,再次提供指示同样多的消息。生成的日志消息如下所示,前两行表明成功部署到暂存,并且没有部署到生产。
-Preparing deploy
-Deploying application
-Skipping a deployment with the s3 provider because a custom condition was not met
当情况反转时,这是一致的:
-Skipping a deployment with the s3 provider because this branch is not permitted: production
-Skipping a deployment with the s3 provider because a custom condition was not met
...
-Preparing deploy
-Deploying application
这导致团队有些混乱,因为消息似乎是假阴性,表明部署在实际按预期运行时失败。我想做的是设置 Travis 以便它只运行适用于该分支和环境变量组合的部署脚本。
有没有办法做到这一点?我的印象是这是有条件部署的方法。
如果没有办法阻止两个部署作业运行,有没有办法抑制作业日志中的消息传递?
解决方案
最好的方法是使用 Travis 的阶段和作业功能。阶段是一组作业。阶段内的作业并行运行。阶段按顺序运行,一个接一个。整个阶段可以是有条件的,阶段也可以包含有条件的作业。阶段中的作业也可以是部署作业(即deploy:
travis.yml 中的整个作业可以嵌套在条件阶段中。最重要的是,对于您的目标,如果条件不满足,条件阶段及其包含的作业将被静默跳过。
deploy:
这与您已经拥有的标准矩阵非常不同。即您当前的部署步骤包含 2 个部署,因此您会收到它正在跳过部署的消息。
相反,您可以将其更改为具有条件作业的单独部署阶段。
使用这样的阶段的缺点是每个阶段都在自己的虚拟机中运行,因此您无法从一个阶段共享数据到下一个阶段。(即来自先前阶段的构建工件不会传播到后续阶段)。例如,您可以通过 S3 共享冗长编译阶段的构建结果来解决此问题。
更多信息可以在这里找到: https ://docs.travis-ci.com/user/build-stages
我的 github 中有一个工作示例:https ://github.com/brianonn/travis-test
jobs:
include:
- stage: compile
script: bash scripts/compile.sh
- stage: test
script: bash scripts/test.sh
- stage: deploy-staging
if: branch = staging
name: "Deploy to staging S3"
script: skip
deploy:
provider: script
script: bash scripts/deploy.sh staging
on:
branch: staging
condition: $TRAVIS_BRANCH = staging
- stage: deploy-prod
if: branch = production
name: "Deploy to production S3"
script: skip
deploy:
provider: script
script: bash scripts/deploy.sh production
on:
branch: production
condition: $TRAVIS_BRANCH = production
这会生成一个特定于暂存和生产的 Travis 作业日志: