Terraform,变量详解

一、定义变量

创建 variables.tf文件,定义变量名为:aws_region。使用default关键字设置默认值:ap-southeast-1。默认值是可选的。如果未设
置默认值,则该变量是必需的。

# variables.tf

variable "aws_region" {
  default = "ap-southeast-1"
}

注意:该文件可以命名为任何名称,因为Terraform加载目录下以*.tf结尾的所有文件。

二、使用变量

通过使用占位符 ${}和var关键字引用定义的变量名。

provider "aws" {
  region     = "${var.aws_region}"
}

三、分配变量

分配变量有多种方法。以变量的优先级考虑,从高到底的顺序主要的方法如下:
Terraform,变量详解

3.1、命令行

可以直接在命令行中使用 -var 标志设置变量 。在该Terraform检查配置的任何命令接受该标志,如apply 和 plan。

terraform apply \
  -var 'aws_region=ap-southeast-1'

注意:以这种方式设置变量不会保存它们,并且在执行命令时必须重复输入它们。

3.2、文件变量

如果想保留变量或者变量是一个固定的值,可以考虑创建后缀为 *.tfvars的文件。文件内容如下:

# terraform.tfvars

aws_region = "ap-southeast-1"

对于当前目录中匹配 terraform.tfvars 或 *.auto.tfvars 存在的所有文件,Terraform会自动加载它们以填充变量。如果文件名为其他名称,则可以-var-file直接使用该标志指定文件。这些文件与Terraform配置文件的语法相同。与Terraform配置文件一样,这些文件也可以是JSON。

terraform apply -var-file="xxx.tfvars"

注意:不建议将用户名和密码保存到版本控制中,但是可以创建一个本地秘钥变量文件用-var-file加载。

-var-file 可以使用多次,指定不同的变量文件。例如:

terraform apply \
  -var-file="secret.tfvars" \
  -var-file="production.tfvars"

3.3、环境变量

Terraform将读取前缀为TFVAR*的环境变量。例如,TF_VAR_aws_region 可以将变量设置为设置aws_region变量。

注意:环境变量只能填充字符串类型的变量。列表和映射类型变量必须通过其他机制之一进行填充。

3.4、默认值

如果没有使用以上任何方法传入变量值,则会采用默认值。

最后需要注意以下几点:

  • 模块内命名唯一
  • 变量间可以引用
  • 不能循环引用

四、高级类型

4.1、列表(Lists)

# 隐式的定义
variable "cidrs" { default = [] }

# 显示的定义
variable "cidrs" { type = list }

terraform.tfvars 文件内容:

cidrs = [ "10.0.0.0/16", "10.1.0.0/16" ]

4.2、字典(Map)

为了合理分配资源,针对不同的运行环境,我们想创建不同类型的服务器实例。例如:dev环境我们只需要用t2.micro,prod环境我们可以配置高一点,使用t2.large。

variable "instance_types" {
  type = "map"
  default = {
    "dev"   = "t2.micro"
    "prod"  = "t2.large"
  }
}

variable "env" {
  default = "dev"
}

resource "aws_instance" "example" {
  instance_type = "${var.instance_types[var.env]}" 
}

在命令行中传值:

terraform apply -var 'instance_types={ dev = "t2.micro", prod = "t2.large" }'

在terraform.tfvars 文件定义值:

instance_types = {
  "dev"  = "t2.micro"
  "prod" = "t2.large"
}

完整示例:

provider "aws" {
  region = "ap-southeast-1"
}

variable "instance_types" {
  type = "map"
  default = {
    "dev"   = "t2.micro"
    "prod"   = "t2.large"
  }
}

variable "env" {
  default = "dev"
}

resource "aws_instance" "example-instance" {
  ami           = "ami-061eb2b23f9f8839c"
  instance_type = "${var.instance_types[var.env]}" 

  tags = {
      Name = "Example by ChangSha Union"
  }
}

output "instance_type" {
  value = "${aws_instance.example-instance.instance_type}"
}

如果您喜欢这篇文章,请考虑关注我。

长沙DevOps联盟 - 关注容器技术,K8S,自动化部署,基础设施架构。
Terraform,变量详解

上一篇:Terraform踩坑记之:Azure Provider配置


下一篇:Terraform踩坑记之:Azure Provider配置