使用模块时无法从terraform.tfstate读取

时间:2019-08-14 17:10:50

标签: amazon-web-services module terraform terraform-provider-aws

我正在使用Terraform v0.12.6。我正在使用模块来创建VPC,子网和EC2实例。

root.tf 
   vpc.tf
   pub_subnet.tf
   web_server.tf 

vpc.tf和pub_subnet.tf运行正常,并显示所需的输出。但是,我无法使用模块pub_subnet.tf中的subnet_id作为我的web_server.tf的输入。

原因是它是一个列表,我为属性“ subnet_id”获取了不合适的值:需要字符串。

好像我必须阅读terraform.tfstate文件。

这是我目前的代码-

root.tf

    provider "aws" {
      region = "us-east-1"
    }
    data "terraform_remote_state" "public_subnet" {
    backend = "local"
    config = {
      path = "terraform.tfstate"
    }
    }
    module "my_vpc" {
      source = "../modules/vpc_flowlogs"
      vpc_cidr = "10.0.0.0/16"
     # vpc_id  = "${module.my_vpc.vpc_id}"
       }

    module "vpc_igw" {
      source = "../modules/vpc_igw"  
      vpc_id  = "${module.my_vpc.vpc_id}"

    }
    module "public_subnets" {
      source="../modules/pub_subnets"
      vpc_id  = "${module.my_vpc.vpc_id}"
    }

     module "web_servers" {
    source = "../modules/webservers"
    vpc_id  = "${module.my_vpc.vpc_id}"
    subnet_id = 
    "${data.terraform_remote_state.public_subnet.outputs.subnet_id[0]}"
    } 

web_servers.tf

resource "aws_instance" "web-srvs" {
count="${var.instance_count == "0" ? "1" : var.instance_count}"
ami = "ami-035b3c7efe6d061d5"
instance_type = "t2.nano"
key_name="xxx-dev"
subnet_id = "${var.subnet_id}"
vpc_security_group_ids = ["${aws_security_group.pub_sg.id}"]
associate_public_ip_address=true
}

我正在尝试使用创建的两个subnet_id。 我尝试了不同的方法,但现在想法不多了。 就像FYI一样,我的tfstate文件与root.tf

位于同一目录中。

感谢任何帮助。还是这是一个错误?

1 个答案:

答案 0 :(得分:0)

您无缘无故请求远程状态。远程状态用于引用其他配置的输出。您有模块,因此只需更改它即可引用模块资源,但是您将不得不在模块中输出值,以便可以在其他位置引用它。

subnet_id = 
    "${data.terraform_remote_state.public_subnet.outputs.subnet_id[0]}"
    } 

Should be

subnet_id = 
    "${module.public_subnets.subnet.id}"
    }

在您的子网模块中,创建输出资源。

output "subnet" {
  value = "${aws_subnet.some_subnet.id}"
}