поэтому я пытаюсь выполнить интерполяцию с помощью public scheme
и terraform.workspace
, чтобы подсети выбирались динамически. Для этого попытался объединить terraform.workspace
с elb_subnets
, но его ошибка выдала только поддерживаемый ключ для интерполяции 'terraform.X' - 'рабочая область'
variable "elb_scheme" {
default = "public"
}
variable "prod_elb_subnets" {
type = "map"
default = {
public = "subnet-23ywe324, subnet-234hj34, subnet-cdh7868"
private = "subnet-hj3h2323, subnet-jihi782, subnet-237dew"
}
}
variable "qa_elb_subnets" {
type = "map"
default = {
public = "subnet-234ee234, subnet-da238sdf, subnet-sd2233"
private = "subnet-09jsdf23, subnet-hi232rf, subnet-89832w32"
}
}
setting {
namespace = "aws:ec2:vpc"
name = "ELBSubnets"
value = "${var.(terraform.workspace_elb_subnets["${var.elb_scheme}"])}"
}
выход:
Error: module.ebs.aws_elastic_beanstalk_environment.beanstalk: 1 error(s) occurred:
* module.ebs.aws_elastic_beanstalk_environment.beanstalk: terraform.workspace_elb_subnets: only supported key for 'terraform.X' interpolations is 'workspace'
Рабочее пространство Terraform
terraform workspace list
default
* qa
Вы можете добиться желаемого результата, используя вложенную карту и используя terraform.workspace
в качестве ключа. Вот так
variable "elb_scheme" {
default = "public"
}
variable "subnets" {
type = "map"
default = {
prod = {
public = "subnet-23ywe324, subnet-234hj34, subnet-cdh7868"
private = "subnet-hj3h2323, subnet-jihi782, subnet-237dew"
}
qa = {
public = "subnet-234ee234, subnet-da238sdf, subnet-sd2233"
private = "subnet-09jsdf23, subnet-hi232rf, subnet-89832w32"
}
}
}
output "my_subnets" {
value = "${lookup(var.subnets[terraform.workspace],"${var.elb_scheme}")}"
}
Как искать как сам список, а не как строку, разделенную запятыми