0

我显然不明白在 CodePipeline 中部署模板时如何使用动态参数。这是基本场景:

CodeBuild BUILD Action - 例如,在这里我检索了 COMMIT_NUMBER 的值。这可以设置为环境变量,或保存到文件中......无论需要做什么。在 post_build 步骤中,我使用“sam package ....”打包模板

CloudFormation DEPLOY 阶段 - 我在这里使用

new codepipeline_actions.CloudFormationCreateUpdateStackAction({
      actionName: `The_Deploy`,
      templatePath: buildOutput.atPath(TEMPLATE_FILE_NAME),
      parameterOverrides, --These are known when I synth the pipeline
      stackName: envStackName,
      cfnCapabilities: [CfnCapabilities.AUTO_EXPAND, CfnCapabilities.ANONYMOUS_IAM],
      adminPermissions: true,
      role: buildRole,
      runOrder: runOrder || 1
    });

部署打包好的模板。在此方法的 props 中,有一个 parameterOverrides 属性,但其中的任何内容都必须在构建时知道。

我的问题是如何将构建步骤中已知的动态参数值设置为部署步骤使用的参数。

感谢您的澄清!

4

1 回答 1

0

谢谢@Ronan Cunningham,提供链接:这里。澄清如何做到这一点的关键点是下面的这句话,我还没有找到很好的解释:

“由于命名空间是本机 CodePipeline 功能,它们不仅限于 CloudFormation 操作。现在,您还可以以动态方式定义 CodeBuild 环境变量(也可以在 CodeBuild 中定义导出变量 - 这些值将成为步骤输出值):“ ....

在这里将它们组合在一起是允许我在 codebuild 操作中设置环境变量并将其传递给 CDK 中的 cloudformation 参数的关键部分:

1.) 在构建项目中添加环境变量和导出变量

const buildProject = new codebuild.PipelineProject(construct, `buildProject`, {
    buildSpec: codebuild.BuildSpec.fromObject({
    version: '0.2',
    env: {
      "variables": {
        "MY_IMPORTANT_INFO": "some-default-value-here"
      },
      "exported-variables": [ "MY_IMPORTANT_INFO" ]
    },
    phases: {
      install: {...},
      build: {
        commands: [ NOTE... variable above can be changed here...]
      }
    },
    artifacts: {...}
    role: buildRole
  })

2.) 将命名空间添加到构建操作:

new codepipeline_actions.CodeBuildAction({
      actionName: `The_Build`,
      project: buildProject,
      input: sourceOutput,
      outputs: [buildOutput],
      role: buildRole,
      variablesNamespace: 'build'
    })

3.) 在部署阶段,我现在可以通过将参数名称设置为在构建步骤中导出的环境变量来设置 ParameterOverride:

new codepipeline_actions.CloudFormationCreateUpdateStackAction({
      actionName: `The_Deploy`,
      templatePath: buildOutput.atPath(TEMPLATE_FILE_NAME),
      parameterOverrides: [
        {"COMMIT_NUMBER": "#{build.MY_IMPORTANT_INFO}"}
      ],
      stackName: envStackName,
      cfnCapabilities: [CfnCapabilities.AUTO_EXPAND, CfnCapabilities.ANONYMOUS_IAM],
      adminPermissions: true,
      role: buildRole,
      runOrder: runOrder || 1
    });

哈利路亚!

而且,再次感谢 Ronan 提供的信息链接!

于 2021-09-27T16:03:09.610 回答