Skip to content

Что такое Terraform

Коротко:

Terraform — Infrastructure as Code tool от HashiCorp (2014). Пишете desired state cloud resources в HCL (HashiCorp Configuration Language), terraform apply creates/updates. Supports AWS, GCP, Azure, Yandex Cloud, Cloudflare, GitHub — через 3000+ providers. Август 2023: HashiCorp сменил license с MPL на BSL (Business Source License) → community fork **OpenTofu** (Linux Foundation, 100% compatible).

Ниже: подробности, пример, смежные термины, FAQ.

Подробности

  • HCL: JSON-like syntax для resource definitions
  • State file: tracks real resources (local или remote S3 + DynamoDB lock)
  • Providers: AWS, GCP, Cloudflare, GitHub, Vault, Helm — через terraform registry
  • Modules: reusable chunks (VPC module, K8s cluster module)
  • OpenTofu: fork после BSL — compatible, Linux Foundation

Пример

# AWS EC2 instance
resource "aws_instance" "web" {
  ami           = "ami-0c55b159cbfafe1f0"
  instance_type = "t3.small"
  tags = { Name = "WebServer" }
}

# Remote state в S3
terraform {
  backend "s3" {
    bucket = "tfstate"
    key    = "prod/terraform.tfstate"
    region = "us-east-1"
  }
}

Смежные термины

Больше по теме

Часто задаваемые вопросы

Terraform или OpenTofu?

OpenTofu: free, MPL license, Linux Foundation. Terraform: BSL (некоммерческим ok, commercial vendors restricted). Для most teams — OpenTofu safer long-term.

State management?

Remote backend обязателен для teams: S3 + DynamoDB (lock), Terraform Cloud, или gitlab-managed-terraform-state. Local state = race conditions.

Terraform vs Pulumi?

Pulumi — IaC на real programming languages (TS, Python, Go). Terraform — HCL DSL. Pulumi better для developers, Terraform для sysadmins.