Files
but3-iac/terraform/modules/compute/main.tf

99 lines
2.1 KiB
Terraform
Raw Normal View History

resource "google_compute_instance" "frontend" {
2025-12-04 09:33:27 +01:00
name = "frontend-${substr(var.zone, -1, 2)}"
project = var.project_id
zone = var.zone
2025-12-04 09:33:27 +01:00
machine_type = var.instance_type
labels = merge({tier = "frontend"}, var.labels)
boot_disk {
initialize_params {
image = "debian-cloud/debian-11"
size = 10
2025-12-04 09:33:27 +01:00
type = "pd-standard"
}
}
network_interface {
2025-12-04 10:05:03 +01:00
network = var.network_id
subnetwork = var.frontend_subnet_id
2025-12-04 09:33:27 +01:00
access_config {}
}
metadata = {
enable-oslogin = "TRUE"
2025-12-04 09:33:27 +01:00
ssh-keys = var.ssh_pub_key
}
tags = ["frontend", "ssh"]
2025-12-04 09:33:27 +01:00
service_account {
email = var.service_account_email
scopes = ["userinfo-email", "compute-ro"]
}
}
resource "google_compute_instance" "backend" {
2025-12-04 09:33:27 +01:00
name = "backend-${substr(var.zone, -1, 2)}"
project = var.project_id
zone = var.zone
2025-12-04 09:33:27 +01:00
machine_type = var.instance_type
labels = merge({tier = "backend"}, var.labels)
boot_disk {
initialize_params {
image = "debian-cloud/debian-11"
size = 10
2025-12-04 09:33:27 +01:00
type = "pd-standard"
}
}
network_interface {
2025-12-04 10:05:03 +01:00
network = var.network_id
subnetwork = var.backend_subnet_id
}
metadata = {
enable-oslogin = "TRUE"
2025-12-04 09:33:27 +01:00
ssh-keys = var.ssh_pub_key
}
tags = ["backend", "ssh"]
2025-12-04 09:33:27 +01:00
service_account {
email = var.service_account_email
scopes = ["userinfo-email", "compute-ro"]
}
}
resource "google_compute_instance" "database" {
2025-12-04 09:33:27 +01:00
name = "database-${substr(var.zone, -1, 2)}"
project = var.project_id
zone = var.zone
2025-12-04 09:33:27 +01:00
machine_type = var.instance_type
labels = merge({tier = "database"}, var.labels)
boot_disk {
initialize_params {
image = "debian-cloud/debian-11"
size = 20
2025-12-04 09:33:27 +01:00
type = "pd-standard"
}
}
network_interface {
2025-12-04 10:05:03 +01:00
network = var.network_id
subnetwork = var.database_subnet_id
}
metadata = {
enable-oslogin = "TRUE"
2025-12-04 09:33:27 +01:00
ssh-keys = var.ssh_pub_key
}
tags = ["database", "ssh"]
2025-12-04 09:33:27 +01:00
service_account {
email = var.service_account_email
scopes = ["userinfo-email", "compute-ro"]
}
}