我正在使用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
位于同一目录中。感谢任何帮助。还是这是一个错误?
答案 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}"
}