Huz*_*afi 5 amazon-web-services aws-codepipeline aws-codebuild
我有一个来自 CodeCommit 的用于 Lambda (NodeJS) Auto Deploy 的流水线。
我的 buildspec.yml
version: 0.1
phases:
install:
commands:
- npm install
- aws cloudformation package --template-file samTemplate.yaml --s3-bucket codepipeline-551 --output-template-file outputSamTemplate.yaml
artifacts:
type: zip
files:
- samTemplate.yaml
- outputSamTemplate.yaml
Run Code Online (Sandbox Code Playgroud)
我的 samTemplate.yaml
AWSTemplateFormatVersion: '2010-09-09'
Transform: 'AWS::Serverless-2016-10-31'
Description: An AWS Serverless Specification template describing your function.
Resources:
KashIoTLambda:
Type: 'AWS::Serverless::Function'
Properties:
Handler: lambda.handler
Runtime: nodejs8.10
CodeUri: ./
Description: ''
MemorySize: 128
Timeout: 3
Role: 'arn:aws:iam::1234:role/abc-backend'
Events:
Api1:
Type: Api
Properties:
Path: '/{proxy+}'
Method: OPTIONS
Api2:
Type: Api
Properties:
Path: /MyResource
Method: ANY
Environment:
Variables:
REGION: ap-south-1
Run Code Online (Sandbox Code Playgroud)
附加到提到的角色的策略可以CodeBuild访问所有资源和所有 S3 命令。
但是,我从构建日志中收到以下错误
[Container] 2019/01/03 13:25:39 Running command npm install
added 122 packages in 3.498s
[Container] 2019/01/03 13:25:44 Running command aws cloudformation package --template-file samTemplate.yaml --s3-bucket codepipeline-551 --output-template-file outputSamTemplate.yaml
Unable to upload artifact ./ referenced by CodeUri parameter of ABCLambda resource.
An error occurred (AccessDenied) when calling the PutObject operation: Access Denied
[Container] 2019/01/03 13:25:46 Command did not exit successfully aws cloudformation package --template-file samTemplate.yaml --s3-bucket codepipeline-551 --output-template-file outputSamTemplate.yaml exit status 255
[Container] 2019/01/03 13:25:46 Phase complete: INSTALL Success: false
[Container] 2019/01/03 13:25:46 Phase context status code: COMMAND_EXECUTION_ERROR Message: Error while executing command: aws cloudformation package --template-file samTemplate.yaml --s3-bucket codepipeline-551 --output-template-file outputSamTemplate.yaml. Reason: exit status 255
Run Code Online (Sandbox Code Playgroud)
检查存储桶本身的策略/权限。
如果您像我一样,您可能default location在第一次设置时在管道设置中选择了该选项作为工件存储。在这种情况下,S3 存储桶本身可能存在阻止访问的策略。
对我来说,一旦删除存储桶策略,unable to upload artifact错误就得到解决,并且我的构建过程继续成功完成。
我希望这可以帮助你。
| 归档时间: |
|
| 查看次数: |
1814 次 |
| 最近记录: |