我正在使用 Cloudformation 创建 Elastic Beanstalk 环境。我必须创建一个 ApplicationVersion 只是为了启动它并将其输入到环境的定义中。我创建其他应用程序版本并以其他方式将它们部署到集群(CodePipeline)。
现在,每次我需要更新 Cloudformation 堆栈以更改其他一些基础设施时,即使它没有将其列为潜在的资源更改,它也会将 ApplicationVersion 回滚到初始版本,并且我必须手动更新环境再次升级到最新版本。
我知道发生了什么 - Cloudformation 只是试图保持模板所描述的堆栈。我只定义了初始的 ApplicationVersion,因为它是 Beanstalk 环境的要求。还有其他办法吗?
CloudFormation 希望掌控一切。根据您执行的堆栈更新,CloudFormation 将根据模板中定义的内容重新创建版本。
不要将您的版本从 Code Pipeline 直接部署到 Elastic Beanstalk,而是执行以下操作:
- 不要将初始版本硬编码到您的 CloudFormation 模板中。
- 将正在部署的版本连接到 CloudFormation 堆栈的输入参数。例如,让输入参数为版本内部版本号,并在模板中构造一个 URL 作为版本源。
- 部署时,指示 Code Pipeline 使用更新的内部版本号更新您的堆栈。 CloudFormation 应通过构建新 URL 并部署版本来接管。
一个例子:
假设你有一个参数ZipBucket
and ZipObject
在你的堆栈中,你可以在你的AWS::ElasticBeanstalk::ApplicationVersion
资源:
"SourceBundle" : {
"S3Bucket" : {
"Ref" : "ZipBucket"
},
"S3Key" : {
"Ref" : "ZipObject"
}
}
另一种选择是有一个BuildNumber
参数,然后使用Fn::Join
in the S3Key
属性以根据内部版本号构建 URL。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)