- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在做一些我认为很简单的事情,但我需要做一些非常棘手的事情,所以我猜有更好的方法。我有一组 AWS lambdas(在 java 中,但这可能无关紧要)我想放入 CI/CD。所以我现在拥有的是一个带有源代码的代码提交仓库;我有一个代码构建工作来构建它们并更新 lambda 的 Gamma 版本。然后我有另一个带有集成测试的代码提交 repo 协议(protocol),以及一个构建测试并运行它们的代码构建作业(如果测试失败则无法构建)。我用 codepipeline 将它们连接在一起,一切都很好!
除了如果测试通过,我想自动更新 prod lambda 的函数代码。我能看到做到这一点的唯一方法是进行第三次代码构建工作,而不是运行一个 buildspec.yml,它除了运行“aws lambda update-function-code”之外什么都不做。仅仅为此运行整个代码构建似乎真的是错误的。 codepipeline 中是否有一种方法可以直接使用管道中的工件之一更新 lambda 函数代码?
我看到我可以将 cloudformation 放入管道中,但这看起来需要一个新的 cloudformation 文件 - 我不想更新编队或 lambda 配置,只更新代码。
更新:我使用了 AWS 推荐的方法一段时间,但不得不放弃它。当您执行此操作时,它会将一个角色附加到 cloudformation 堆栈,并且除非附加的角色具有所需的权限,否则以后对堆栈的任何手动更新都会失败。因此,您要么必须授予 AWS 对您的 CI/CD 管道的完全访问权限,要么在您手动编辑您的堆栈并进行部署时陷入困境。
最后,一个对我来说效果更好的解决方案是简单地编写一个 deployspec.yml 文件,该文件获取一个工件并将其发送到 lambda,将其粘贴到我的 lambda 源代码存储库中,并将其作为构建阶段运行.问题已解决,并且不会破坏我的 cloudformation 堆栈。
最佳答案
AWS 有一个关于 Lambda 函数的 CI/CD 管道的很棒的教程 [1]。这使用 CodePipeline 和 CloudFormation。这是最好的建议方法,我强烈建议您使用它,即使您可能需要学习一些 CloudFormation,但从长远来看它是值得的。
[1] https://docs.aws.amazon.com/lambda/latest/dg/build-pipeline.html
关于aws-lambda - AWS codepipeline - 如何更新 lambda 的函数代码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59440062/
我目前正在使用 codepipeline、codebuild、codedeploy 和 codecommit 创建管道。我在将 codebuild 构建工件上传到 s3 时遇到问题,因为它不遵循我在
我已经设置了一个管道,用于监视具有给定分支的 codeCommit 存储库,并且它运行良好。 我想限制我的管道只观看我的 repo 中的一个文件夹。想象一下,我的 repo 包含两个文件夹:fold1
我们使用 monorepo 方法将我们的源代码存储在 github 中。 当前是否可以仅在提交到特定子文件夹时触发 CodePipeline。 通过在源存储库上设置过滤器,TeamCity 目前可以实
我有一个在构建阶段调用 CodeBuild 的 AWS CodePipeline。 问题是如何从 CodePipeline 传入可以在 CodeBuild 的 buildspec.yml 中读取的环境
我有一个使用 AWS codebuild 构建 AMI 的 codepipeline,我计划每周运行一个新的服务器镜像。 我想将其作为计划任务运行,我考虑使用 lambda 计划任务,但没有看到从 l
我正在设置 CodePipeline,并创建了一个操作来从 GitHub 获取源代码。 这需要建立一个连接,我做到了,而且在 GitHub 方面看起来也很好。 但是,如果我发布对管道的更改,我会在源阶
如果您通过 CloudFormation 创建 CodePipeline。它会自动启动它,这可能是一个问题,因为管道可以重写相同的堆栈...... 有什么方法可以禁用此行为吗? 谢谢。 最佳答案 有同
我正在设置一个管道来自动执行 cloudformation 堆栈模板部署。 管道本身是在 aws eu-west-1 区域中创建的,但 cloudformation 堆栈模板将部署在任何其他区域中。
尽管计划已正确应用,但我的 Terraform 代码在应用后仍会报告更改。 Terraform 和提供者版本: Terraform v1.1.7 on darwin_amd64 + provider
我们的ci工作流程是这样 在预提交中运行eslint 推送到功能分支 在代码提交中打开拉取请求 触发aws代码构建运行测试 (如果所有测试均通过),请合并 触发AWS代码部署以部署 现在,我注意到co
通过 SLS 部署此 CloudFormation 模板时,我收到一条神秘的错误消息,但没有来自 CloudFormation Events 的更多信息: FrontendPipeline:
是否可以使用 Cloudformation 作为部署提供者向 Codepipeline 创建的堆栈添加标签? 最佳答案 如this documentation表示您可以在模板配置文件中为堆栈设置标签。
我正在尝试构建 Angular7 项目并将其部署到 S3,但出现以下错误。我该如何解决? [Container] 2019/05/21 04:08:49 Waiting for agent ping
借助 Bitbucket 和 Bamboo,我能够让 Bamboo 跟踪每个功能分支并在每个分支上运行测试,以便在 pull 请求时,我能够查看该分支是否通过了单元测试。 与 AWS CodePipe
我使用 terraform 模块设计了一个 AWS 代码管道模块,我有多个使用代码管道模块的实际代码管道。我使用模块作为设计模式,因为所有的代码流水线看起来都很相似,除了一些代码流水线需要批准阶段,一
一个简单的构建规范,例如: version: 0.2 phases: install: commands: - (cd lambda/src; npm install)
AWS CodePipeline现在支持GitHub WebHook,但默认情况下 每次在master分支上推送(更改)代码时,都会触发CodePipeline。 但是,我只希望它在实际发布发行版时运
我的团队一直在使用我们的 CodePipeline 遇到问题,在这些问题中,由于我们的 Docker 镜像修补而将不应该出现的功能推送到生产中。关于我们架构的一点背景:我们的管道有两个来源,一个用于源
是否有关于 CodePipeline 中阶段超时的文档/详细信息?特别是,我有一个构建阶段 (Jenkins),如果 Jenkins 配置不正确,它可能会失败,但它并不总是立即使 CodePipeli
我一直在使用 AWS CDK,我认为这是使用 AWS 的好方法。最近我遇到了一个我无法解决的问题。查看了文档和资源,但没有人解释如何在 CDK 中执行此操作。因此,我有两个代码管道,每个管道要么部署到
我是一名优秀的程序员,十分优秀!