Variable
输入变量用作Terraform模块的参数, variable作为输入变量,可以被terraform 脚本引用,我们可以直接在命令行中直接给变量赋值,或者引用变量文件。
变量接受以下参数:
- type:(可选)-如果设置,则定义变量的类型。有效值是string,list和map。如果省略此字段,则将基于推断变量类型default。如果未default提供,则假定类型为string。
- default:(可选)-设置变量的默认值。如果未提供默认值,则如果调用者未提供值,Terraform将引发错误。缺省值可以是任何受支持的数据类型,如下所述。如果type还设置,则给定值必须是指定的类型。
- description:(可选)-变量的人性化描述。这主要是针对使用Terraform配置的用户的文档。在Terraform Registry中发布模块时,给定的描述将显示为文档的一部分。
variable "ecs_role" {
description = "arn of the role"
type = string
default="role"
}
variable "valid_env" {
description = "Valid environments available."
type = map(string)
default = {
dev = "dev"
qa = "qa"
}
}
variable "subnets" {
description = "Public subnets list"
type = list(string)
default= ["subnet-1","subnet-2","subnet-3" ]
}
variable "boolean" {
description = "The aws boolean"
type=boolean
default=true
}
variables应用:
可以在terraform 脚本中引用变量
resource "aws_ecr_repository" "ecr" {
name = var.name
tags=var.tags
}
可以在plan,apply, destroy 中引用 variable
$ terraform apply -var-file=foo.tfvars -var-file=bar.tfvars
$ terraform apply -var foo=bar -var foo=baz
对于当前目录中匹配terraform.tfvars或*.auto.tfvars存在的所有文件,Terraform会自动加载它们以填充变量。如果文件位于其他位置,则可以使用该-var-file标志将路径传递到文件 。建议使用以结尾的文件命名此类文件 .tfvars
按以下顺序传递它们时:
$ terraform apply -var-file=foo.tfvars -var-file=bar.tfvars
结果将是baz将包含该值,bar因为bar.tfvars 已加载了最后一个定义。
使用该-var-file标志传递的定义文件将始终在工作目录中的文件之后进行评估。
在定义文件中或其中传递的值-var将优先于 TF_VAR_环境变量,因为环境变量被视为默认值。