Terraform多个S3存储桶创建

时间:2020-09-07 10:34:38

标签: amazon-web-services amazon-s3 terraform terraform-provider-aws bucket

我正在尝试创建多个s3存储桶,每个存储桶设置不同。我正在寻找有关如何在其他存储桶资源块中引用动态创建的存储桶的存储桶ID的语法。 terraform的新手。寻找这种语法的示例代码或Terrraform文档

Bel0w是用于从列表名称创建存储桶的示例代码

resource "aws_s3_bucket" "this" {
  count=length(var.bucket_names)
  bucket = var.bucket_names[count.index]
  acl="private"

  versioning {
    enabled = var.bucket_versioning
  }
}

在此代码中,我想引用动态创建的存储桶ID并分配其存储桶策略设置。需要语法。不知道这是否正确

resource "aws_s3_bucket_policy" "this" {
  count=length(var.bucket_names)
  bucket = aws_s3_bucket.this.id[count.index]
  policy = data.aws_iam_policy_document.this.json
}

1 个答案:

答案 0 :(得分:3)

在您的aws_s3_bucket_policy中,而不是

bucket = aws_s3_bucket.this.id[count.index]

应该是

bucket = aws_s3_bucket.this[count.index].id

假设其他所有内容都是正确的,例如data.aws_iam_policy_document.this.json有效。