Comment utiliser terraform avec des variables d'environnement.fichier tf

je suis nouveau à transformer le terrain et j'ai rencontré un problème lors de l'utilisation de variables d'environnement .tf fichier, j'ai essayé d'utiliser terraform.tfvars/variables.tf.

./terraform apply -var-file="terraform.tfvars"
Failed to load root config module: Error parsing variables.tf: At 54:17: illegal char

Qu'est-ce que je rate ici?

Version Terraform:Terraform v0.9.2

main.tf:

provider "aws" {
  access_key = "${var.aws_access_key}"
  secret_key = "${var.aws_secret_key}"
  region = "${var.aws_region}"
  allowed_account_ids = ["${var.aws_account_id}"]
}

resource "aws_instance" "db" {

  ami           = "ami-49c9295"
  instance_type = "t2.micro"

  tags {
    Name = "test"
  }

  connection {
   user = "ubuntu"
  }

  security_groups = ["sg-ccc943b0"]
  availability_zone = "${var.availability_zone}"
  subnet_id = "${var.subnet_id}"
}

terraform.tfvars:

aws_profile = "default"
aws_access_key = "xxxxxx"
aws_secret_key = "xxxxxx"
aws_account_id = "xxxxxx"
key_name = "keyname"
key_path = "/home/user/.ssh/user.pem"
aws_region = "us-east-1"
subnet_id = "subnet-51997e7a"
vpc_security_group_ids = "mysql"
instance_type = "t2.xlarge"
availability_zone = "us-east-1a"

variables.tf:

variable "key_name" {
    description = "Name of the SSH keypair to use in AWS."
    default     = "keypairname"
}

variable "key_path" {
    description = "Path to the private portion of the SSH key specified."
    default     = "/home/user/.ssh/mypem.pem"
}

variable "aws_region" {
    description = "AWS region to launch servers."
    default     = "us-east-1"
}

variable "aws_access_key" {
    decscription = "AWS Access Key"
    default     = "xxxxxx"
}

variable "aws_secret_key" {
    description = "AWS Secret Key"
    default     = "xxxxxx"
}

variable "aws_account_id" {
    description = "AWS Account ID"
    default     = "xxxxxx"
}

variable "subnet_id" {
    description = "Subnet ID to use in VPC"
    default     = "subnet-51997e7a"
}

variable "vpc_security_group_ids" {
    description = "vpc_security_group_ids"
    default     = "sec"
}

variable "instance_type" {
    description = "Instance type"
    default     = "t2.xlarge"
}

variable "instance_name" {
    description = "Instance Name"
    default     = "test"
}

variable "availability_zone" {
    description = "availability_zone"
    default     = "us-east-1a"
}

variable "aws_amis" {
    default = {
        "us-east-1": "ami-49c9295f",
        "eu-west-1": "ami-49c9295f",
        "us-west-1": "ami-49c9295f",
        "us-west-2": "ami-49c9295f"
    }
}

mise à Jour

après avoir enlevé variable "aws_amis" article de variables.tf, j'ai couru dans un autre numéro:

Failed to load root config module: Error loading variables.tf: 1 error(s) occurred:
* variable[aws_access_key]: invalid key: decscription
8
demandé sur Berlin 2017-04-13 15:15:51

1 réponses

aws_amis variable étant utilisée comme une carte de recherche semble mal formatée pour moi. Au lieu de cela, il devrait probablement être de la forme:

variable "aws_amis" {
    default = {
        us-east-1 = "ami-49c9295f"
        eu-west-1 = "ami-49c9295f"
        us-west-1 = "ami-49c9295f"
        us-west-2 = "ami-49c9295f"
    }
}

en tant que Terraform, cherche une terraform.tfvars de fichier par défaut de sorte que vous pouvez supprimer l' -var-file="terraform.tfvars". Vous aurez besoin de passer l' -var-file option si vous souhaitez utiliser un fichier nommé différemment (comme prod.tfvars) mais pour cela, vous pouvez l'omettre.

4
répondu ydaetskcoR 2017-04-14 15:57:40