infrastructure/pve01.wheatley.in/k8s-wheatley/main.tf

171 lines
4.8 KiB
Terraform
Raw Permalink Normal View History

2025-11-27 17:08:20 +01:00
terraform {
backend "s3" {
bucket = "13225-wheatley-states"
key = "k8s-wheatley.tfstate"
region = "main"
skip_credentials_validation = true
skip_metadata_api_check = true
skip_region_validation = true
force_path_style = true
}
}
2025-10-24 23:41:05 +02:00
provider "proxmox" {
endpoint = var.proxmox_endpoint
api_token = var.proxmox_api_token
2025-10-24 23:41:05 +02:00
}
locals {
cluster_name = "k8s-wheatley"
2025-10-31 17:24:40 +01:00
vm-id_prefix = 200
kubernetes_version = "1.34.1"
2025-11-15 20:49:31 +01:00
talos_version = "1.11.5"
gateway_api_version = "1.3.0"
cilium_version = "1.18.4"
2025-11-18 22:14:35 +01:00
ipv4_gateway = "10.13.37.1"
cluster_endpoint_ip = "10.13.37.10"
2025-10-28 22:45:12 +01:00
proxmox_node = "pve01"
2025-10-24 23:41:05 +02:00
controlplanes = {
cpu = 4
2025-11-15 20:49:31 +01:00
memory = 8
2025-11-18 22:14:35 +01:00
disk = 20
2025-10-26 19:39:29 +01:00
storagepool = "nvme-fastpool"
talos_version = local.talos_version
cluster_name = local.cluster_name
kubernetes_version = local.kubernetes_version
ipv4_gateway = local.ipv4_gateway
2025-10-24 23:41:05 +02:00
nodes = [
{
name = "cp01"
2025-11-18 22:14:35 +01:00
ip_address = "10.13.37.11"
2025-10-24 23:41:05 +02:00
},
{
name = "cp02"
2025-11-18 22:14:35 +01:00
ip_address = "10.13.37.12"
2025-10-24 23:41:05 +02:00
},
{
name = "cp03"
2025-11-18 22:14:35 +01:00
ip_address = "10.13.37.13"
2025-10-28 22:45:12 +01:00
},
]
2025-10-24 23:41:05 +02:00
}
2025-10-28 22:45:12 +01:00
controlplane_addresses = [
for node in local.controlplanes.nodes : node.ip_address
]
2025-10-24 23:41:05 +02:00
workers = {
2025-11-15 20:49:31 +01:00
cpu = 8
memory = 8
disk = 40
2025-10-26 19:39:29 +01:00
storagepool = "nvme-fastpool"
talos_version = local.talos_version
cluster_name = local.cluster_name
kubernetes_version = local.kubernetes_version
ipv4_gateway = local.ipv4_gateway
2025-11-15 20:49:31 +01:00
pvc_disks = [100]
2025-10-24 23:41:05 +02:00
nodes = [
{
name = "worker01"
2025-11-18 22:14:35 +01:00
ip_address = "10.13.37.21"
2025-10-24 23:41:05 +02:00
},
{
name = "worker02"
2025-11-18 22:14:35 +01:00
ip_address = "10.13.37.22"
},
{
name = "worker03"
2025-11-18 22:14:35 +01:00
ip_address = "10.13.37.23"
2025-10-28 22:45:12 +01:00
},
]
}
2025-10-28 22:45:12 +01:00
worker_addresses = [
for node in local.workers.nodes : node.ip_address
]
}
module "controlplanes" {
2025-10-28 22:45:12 +01:00
source = "./modules/talos-node"
for_each = { for node in local.controlplanes.nodes : node.name => node }
2025-10-28 22:45:12 +01:00
node = {
2025-11-15 20:49:31 +01:00
id = local.vm-id_prefix + 10 + tonumber(replace(each.key, "cp", ""))
name = format("k8s-wheatley-%s", each.value.name)
ipv4_address = each.value.ip_address
cpu = local.controlplanes.cpu
memory = local.controlplanes.memory
disk = local.controlplanes.disk
storagepool = local.controlplanes.storagepool
talos_version = local.talos_version
cluster_name = local.cluster_name
kubernetes_version = local.kubernetes_version
cluster_endpoint = local.cluster_endpoint_ip
ipv4_gateway = local.ipv4_gateway
proxmox_node = local.proxmox_node
}
}
module "workers" {
2025-10-28 22:45:12 +01:00
source = "./modules/talos-node"
for_each = { for node in local.workers.nodes : node.name => node }
2025-10-28 22:45:12 +01:00
node = {
2025-11-15 20:49:31 +01:00
id = local.vm-id_prefix + 20 + tonumber(replace(each.key, "worker", ""))
name = format("k8s-wheatley-%s", each.value.name)
ipv4_address = each.value.ip_address
cpu = local.workers.cpu
memory = local.workers.memory
disk = local.workers.disk
storagepool = local.workers.storagepool
talos_version = local.talos_version
cluster_name = local.cluster_name
kubernetes_version = local.kubernetes_version
cluster_endpoint = local.cluster_endpoint_ip
ipv4_gateway = local.ipv4_gateway
proxmox_node = local.proxmox_node
2025-10-24 23:41:05 +02:00
}
2025-11-15 20:49:31 +01:00
pvc_disks = local.workers.pvc_disks
2025-10-24 23:41:05 +02:00
}
2025-10-28 22:46:17 +01:00
module "talos-bootstrap" {
depends_on = [
module.controlplanes,
module.workers
]
source = "./modules/talos-bootstrap"
node_config = {
ipv4_gateway = local.ipv4_gateway
talos_version = local.talos_version
gateway_api_version = local.gateway_api_version
2025-10-28 22:46:17 +01:00
cilium_version = local.cilium_version
cluster_name = local.cluster_name
kubernetes_version = local.kubernetes_version
cluster_endpoint = local.cluster_endpoint_ip
proxmox_node = local.proxmox_node
controlplane_addresses = local.controlplane_addresses
worker_addresses = local.worker_addresses
}
talos_nodes = concat(
[
for node in local.controlplanes.nodes : {
name = format("k8s-wheatley-%s", node.name)
type = "controlplane"
ipv4_address = node.ip_address
}
],
[
for node in local.workers.nodes : {
name = format("k8s-wheatley-%s", node.name)
type = "worker"
ipv4_address = node.ip_address
}
]
)
}