chore: Refactor VM deployment

This commit is contained in:
Peter 2025-10-28 22:45:12 +01:00
parent d2e0c26900
commit 9ca0f7c431
Signed by: Peter
SSH key fingerprint: SHA256:B5tYaxBExaDm74r1px9iVeZ6F/ZDiyiy9SbBqfZYrvg
13 changed files with 192 additions and 328 deletions

View file

@ -8,9 +8,10 @@ locals {
cluster_name = "k8s-wheatley"
kubernetes_version = "1.34.1"
talos_version = "1.11.3"
cilium_version = "1.14.1"
ipv4_gateway = "10.13.38.1"
ipv4_cidr = "/24"
cluster_endpoint_ip = "10.13.38.10"
proxmox_node = "pve01"
controlplanes = {
@ -34,10 +35,14 @@ locals {
{
name = "cp03"
ip_address = "10.13.38.13"
}
},
]
}
controlplane_addresses = [
for node in local.controlplanes.nodes : node.ip_address
]
workers = {
cpu = 4
memory = 4
@ -50,18 +55,30 @@ locals {
nodes = [
{
name = "worker01"
ip_address = "10.13.38.20"
},
{
name = "worker02"
ip_address = "10.13.38.21"
},
{
name = "worker03"
name = "worker02"
ip_address = "10.13.38.22"
}
},
{
name = "worker03"
ip_address = "10.13.38.23"
},
{
name = "worker04"
ip_address = "10.13.38.24"
},
{
name = "worker05"
ip_address = "10.13.38.25"
},
]
}
worker_addresses = [
for node in local.workers.nodes : node.ip_address
]
}
module "talos-image" {
@ -71,43 +88,55 @@ module "talos-image" {
}
module "controlplanes" {
depends_on = [module.talos-image]
depends_on = [module.talos-image]
source = "./modules/controlplane"
source = "./modules/talos-node"
for_each = { for node in local.controlplanes.nodes : node.name => node }
controlplane = {
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
node_name = format("k8s-wheatley-%s", each.value.name)
cluster_endpoint = format("https://%s:6443", local.cluster_endpoint_ip)
node_ipv4_address = format("%s%s", each.value.ip_address, local.ipv4_cidr)
ipv4_gateway = local.ipv4_gateway
node = {
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
controlplane_addresses = local.controlplane_addresses
worker_addresses = local.worker_addresses
}
}
resource "time_sleep" "delay_before_workers" {
depends_on = [module.talos-image]
create_duration = "1s"
}
module "workers" {
depends_on = [module.controlplanes]
depends_on = [time_sleep.delay_before_workers]
source = "./modules/worker"
source = "./modules/talos-node"
for_each = { for node in local.workers.nodes : node.name => node }
worker = {
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
node_name = format("k8s-wheatley-%s", each.value.name)
cluster_endpoint = format("https://%s:6443", local.cluster_endpoint_ip)
node_ipv4_address = format("%s%s", each.value.ip_address, local.ipv4_cidr)
ipv4_gateway = local.ipv4_gateway
node = {
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
controlplane_addresses = local.controlplane_addresses
worker_addresses = local.worker_addresses
}
}