Aula 08 - Cluster Kubernetes HA: - Setup interativo com OpenTofu para Talos na Hetzner - CCM, CSI Driver, Cluster Autoscaler, Metrics Server - NGINX Ingress com LoadBalancer (HTTP/HTTPS/SSH) Aula 09 - n8n na Hetzner: - Deploy via Helm com PostgreSQL e Redis - Suporte multi-tenant com add-client.sh - Integração com Hetzner CSI para volumes persistentes Aula 10 - GitLab na Hetzner: - Setup agnóstico: CloudFlare (trusted proxies) ou Let's Encrypt - Anti-affinity para distribuir webservice/sidekiq em nós diferentes - Container Registry e SSH via TCP passthrough - Documentação do erro 422 e solução com trustedCIDRsForXForwardedFor Melhorias gerais: - READMEs atualizados com arquitetura e troubleshooting - Scripts cleanup.sh para todas as aulas - CLAUDE.md atualizado com contexto do projeto
80 lines
2.2 KiB
HCL
80 lines
2.2 KiB
HCL
############################################################
|
|
# Variables for Hetzner Talos Kubernetes Cluster
|
|
############################################################
|
|
|
|
# ==========================================================
|
|
# AUTENTICAÇÃO
|
|
# ==========================================================
|
|
|
|
variable "hcloud_token" {
|
|
type = string
|
|
description = "Hetzner Cloud API token"
|
|
sensitive = true
|
|
}
|
|
|
|
# ==========================================================
|
|
# CONFIGURAÇÃO DO CLUSTER
|
|
# ==========================================================
|
|
|
|
variable "enable_ha" {
|
|
type = bool
|
|
description = "Enable HA mode with 3 control plane nodes"
|
|
default = true
|
|
}
|
|
|
|
variable "enable_loadbalancer" {
|
|
type = bool
|
|
description = "Enable Hetzner Load Balancer for HA access to control plane and ingress"
|
|
default = true
|
|
}
|
|
|
|
variable "environment" {
|
|
type = string
|
|
description = "Environment name (prod, staging, dev)"
|
|
default = "prod"
|
|
|
|
validation {
|
|
condition = contains(["prod", "staging", "dev"], var.environment)
|
|
error_message = "Environment deve ser: prod, staging ou dev."
|
|
}
|
|
}
|
|
|
|
# ==========================================================
|
|
# SSH
|
|
# ==========================================================
|
|
|
|
variable "ssh_public_key" {
|
|
type = string
|
|
description = "Public SSH key for emergency access to nodes"
|
|
}
|
|
|
|
# ==========================================================
|
|
# TALOS
|
|
# ==========================================================
|
|
|
|
variable "talos_image_id" {
|
|
type = number
|
|
description = "ID da imagem Talos customizada na Hetzner (criada na aula-07). Obtenha com: hcloud image list --type snapshot"
|
|
}
|
|
|
|
variable "talos_version" {
|
|
type = string
|
|
description = "Talos version to use"
|
|
default = "v1.11.2"
|
|
|
|
validation {
|
|
condition = can(regex("^v[0-9]+\\.[0-9]+\\.[0-9]+$", var.talos_version))
|
|
error_message = "talos_version deve seguir o formato semântico: v1.2.3"
|
|
}
|
|
}
|
|
|
|
# ==========================================================
|
|
# LABELS CUSTOMIZADAS
|
|
# ==========================================================
|
|
|
|
variable "custom_labels" {
|
|
type = map(string)
|
|
description = "Custom labels to add to all resources"
|
|
default = {}
|
|
}
|