Eu tenho um arquivo simples na minha .ebextensions
pasta:
00-myconfig.config
Resources:
AWSEBAutoScalingGroup:
Metadata:
AWS::CloudFormation::Authentication:
S3Access:
type: S3
roleName: aws-elasticbeanstalk-ec2-role
buckets: my-bucket
files:
"/tmp/ca-bundle.zip":
mode: "000755"
owner: root
group: root
source: https://s3-ap-southeast-2.amazonaws.com/my-bucket/ca/ca-bundle.zip
authentication: S3Access
Qual, de acordo com várias respostas, é a maneira de conceder acesso ao bucket do S3 para a aws-elasticbeanstalk-ec2-role
função.
Mas continuo recebendo o erro 403 em /var/log/eb-activity.log
[2015-08-26T01:27:03.544Z] INFO [22320] - [Application update/AppDeployStage0/EbExtensionPreBuild/Infra-EmbeddedPreBuild] : Activity execution failed, because: Failed to retrieve https://s3-ap-southeast-2.amazonaws.com/my-bucket/ca/ca-bundle.zip: HTTP Error 403 : <?xml version="1.0" encoding="UTF-8"?> (ElasticBeanstalk::ExternalInvocationError)
Se eu adicionar manualmente uma política de acesso S3 à aws-elasticbeanstalk-ec2-role
função em que tudo funciona, então sei que não tenho erros de ortografia nos URLS ou em qualquer outra coisa, a instância do EC2 está definitivamente na função correta.
O que está errado?
PS. Tentei a files
seção com ou sem a configuração de 'autenticação'.