amazon-web-services - Terraform 多个 s3 存储桶创建

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

我正在尝试创建多个 s3 存储桶,每个存储桶具有不同的存储桶设置。我正在寻找有关如何在其他存储桶资源 block 中引用动态创建的存储桶的存储桶 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
}

最佳答案

在您的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 有效。

关于amazon-web-services - Terraform 多个 s3 存储桶创建,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63775869/

相关文章:

amazon-web-services - 无法删除 CloudFormation 堆栈

json - 在Cloudformation中传递标签的json文件

Azure VMSS 通过 Terraform azapi 手动升级

Terraform aws_ssm_parameter null/empty with ignore_changes

amazon-web-services - 带有Docker和SQS的AWS Beanstalk上的Sinatra应用

amazon-web-services - AWS Lambda - 如何将 ONNX 模型放入 AWS 层中

amazon-web-services - 带有 MFA 代码/ token 的 aws 命令行界面的登录问题

amazon-web-services - Amazon SES 中无法接收电子邮件

testing - CircleCI 与 AWS : RequestTimeTooSkewed error

kubernetes - 带有 EKS 的 Terraform Kubernetes 提供程序在 configmap 上失败