首页 > 解决方案 > Travis CI:如何有条件地运行提供者部署作业?

问题描述

我有一个基于 2 个条件部署到不同 S3 存储桶的 travis 脚本:1. 分支名称 2. $TRAVIS_BRANCHenv 变量

... 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 以便它只运行适用于该分支和环境变量组合的部署脚本
有没有办法做到这一点?我的印象是这是有条件部署的方法。

如果没有办法阻止两个部署作业运行,有没有办法抑制作业日志中的消息传递?

标签: deploymenttravis-cicontinuous-deployment

解决方案


最好的方法是使用 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 作业日志:

推送到暂存分支 推送到生产分支


推荐阅读