我正在为AWS VPC创建创建一个Terraform模块。
这是我的目录结构
➢ tree -L 3
.
├── main.tf
├── modules
│ ├── subnets
│ │ ├── main.tf
│ │ ├── outputs.tf
│ │ └── variables.tf
│ └── vpc
│ ├── main.tf
│ ├── outputs.tf
│ └── variables.tf
└── variables.tf
3 directories, 12 files
在子网模块中,我想抓取 VPC(子(模块的 vpc ID。
在modules/vpc/outputs.tf
我使用:
output "my_vpc_id" {
value = "${aws_vpc.my_vpc.id}"
}
这足以让我在modules/subnets/main.tf
中执行以下操作吗?
resource "aws_subnet" "env_vpc_sn" {
...
vpc_id = "${aws_vpc.my_vpc.id}"
}
您的main.tf
(或使用子网模块的任何位置(都需要从 VPC 模块的输出中传入此变量,并且您的子网模块需要采用的是必需变量。
要访问模块的输出,您需要将其引用为module.<MODULE NAME>.<OUTPUT NAME>
:
,子模块的输出在表达式中作为模块...例如,如果名为 web_server 的子模块声明了名为 instance_ip_addr 的输出,则可以将该值作为 module.web_server.instance_ip_addr 访问。
所以你的main.tf
看起来像这样:
module "vpc" {
# ...
}
module "subnets" {
vpc_id = "${module.vpc.my_vpc_id}"
# ...
}
subnets/variables.tf
看起来像这样:
variable "vpc_id" {}