197 lines
4.1 KiB
HCL
197 lines
4.1 KiB
HCL
locals {
|
|
managers = [
|
|
for i in range(var.manager_count) : {
|
|
name = "${var.swarm_name}-manager-${format("%02s", i + 1)}"
|
|
}
|
|
]
|
|
workers = [
|
|
for i in range(var.worker_count) : {
|
|
name = "${var.swarm_name}-worker-${format("%02s", i + 1)}"
|
|
}
|
|
]
|
|
}
|
|
|
|
resource "proxmox_virtual_environment_pool" "swarm_pool" {
|
|
comment = "Managed by Terraform"
|
|
pool_id = var.swarm_name
|
|
}
|
|
|
|
resource "proxmox_virtual_environment_vm" "swarm_manager" {
|
|
count = var.manager_count
|
|
name = local.managers[count.index].name
|
|
description = "Managed by Terraform"
|
|
tags = ["terraform", "ubuntu", "swarm-manager", var.swarm_name]
|
|
|
|
node_name = "pve"
|
|
vm_id = "${var.vm_id_prefix}${count.index + 101}"
|
|
pool_id = proxmox_virtual_environment_pool.swarm_pool.id
|
|
|
|
cpu {
|
|
cores = 2
|
|
type = "host"
|
|
}
|
|
|
|
memory {
|
|
dedicated = 2048
|
|
floating = 2048
|
|
}
|
|
|
|
agent {
|
|
# read 'Qemu guest agent' section, change to true only when ready
|
|
enabled = true
|
|
}
|
|
|
|
startup {
|
|
order = "1"
|
|
up_delay = "60"
|
|
down_delay = "60"
|
|
}
|
|
|
|
disk {
|
|
datastore_id = var.proxmox_vm_storage
|
|
file_id = var.cloud_image_id
|
|
interface = "virtio0"
|
|
iothread = true
|
|
discard = "on"
|
|
size = 32
|
|
file_format = "qcow2"
|
|
}
|
|
|
|
initialization {
|
|
ip_config {
|
|
ipv4 {
|
|
# x.x.x.32 - x.x.x.39
|
|
address = "${cidrhost(var.subnet_cidr, count.index + 32)}/24"
|
|
gateway = var.gateway
|
|
}
|
|
}
|
|
datastore_id = var.proxmox_image_storage
|
|
|
|
user_data_file_id = var.cloud_init_file_id
|
|
}
|
|
|
|
network_device {
|
|
bridge = "vmbr0"
|
|
}
|
|
|
|
operating_system {
|
|
type = "l26"
|
|
}
|
|
|
|
connection {
|
|
type = "ssh"
|
|
user = "ubuntu"
|
|
private_key = file(var.ssh_private_key_file)
|
|
host = split("/", self.initialization[0].ip_config[0].ipv4[0].address)[0]
|
|
}
|
|
|
|
provisioner "remote-exec" {
|
|
inline = [
|
|
"sudo hostnamectl set-hostname ${self.name}",
|
|
"sudo systemctl restart avahi-daemon",
|
|
]
|
|
}
|
|
|
|
lifecycle {
|
|
ignore_changes = [
|
|
initialization[0].user_data_file_id,
|
|
]
|
|
}
|
|
}
|
|
|
|
|
|
|
|
resource "proxmox_virtual_environment_vm" "swarm_worker" {
|
|
count = var.worker_count
|
|
name = local.workers[count.index].name
|
|
description = "Managed by Terraform"
|
|
tags = ["terraform", "ubuntu", "swarm-worker", var.swarm_name]
|
|
|
|
node_name = "pve"
|
|
vm_id = "${var.vm_id_prefix}${count.index + 301}"
|
|
pool_id = proxmox_virtual_environment_pool.swarm_pool.id
|
|
|
|
cpu {
|
|
cores = 4
|
|
type = "host"
|
|
}
|
|
|
|
memory {
|
|
dedicated = 8192
|
|
floating = 8192
|
|
}
|
|
|
|
agent {
|
|
# read 'Qemu guest agent' section, change to true only when ready
|
|
enabled = true
|
|
}
|
|
|
|
startup {
|
|
order = "2"
|
|
up_delay = "60"
|
|
down_delay = "60"
|
|
}
|
|
|
|
disk {
|
|
datastore_id = var.proxmox_vm_storage
|
|
file_id = var.cloud_image_id
|
|
interface = "virtio0"
|
|
discard = "on"
|
|
size = 32
|
|
file_format = "qcow2"
|
|
}
|
|
|
|
initialization {
|
|
ip_config {
|
|
ipv4 {
|
|
# x.x.x.40 - x.x.x.55
|
|
address = "${cidrhost(var.subnet_cidr, count.index + 40)}/24"
|
|
gateway = var.gateway
|
|
}
|
|
}
|
|
datastore_id = var.proxmox_image_storage
|
|
|
|
user_data_file_id = var.cloud_init_file_id
|
|
}
|
|
|
|
network_device {
|
|
bridge = "vmbr0"
|
|
}
|
|
|
|
operating_system {
|
|
type = "l26"
|
|
}
|
|
|
|
connection {
|
|
type = "ssh"
|
|
user = "ubuntu"
|
|
private_key = file(var.ssh_private_key_file)
|
|
host = split("/", self.initialization[0].ip_config[0].ipv4[0].address)[0]
|
|
}
|
|
|
|
provisioner "remote-exec" {
|
|
inline = [
|
|
"sudo hostnamectl set-hostname ${self.name}",
|
|
"sudo systemctl restart avahi-daemon",
|
|
]
|
|
}
|
|
|
|
lifecycle {
|
|
ignore_changes = [
|
|
initialization[0].user_data_file_id,
|
|
]
|
|
}
|
|
}
|
|
|
|
resource "ansible_host" "swarm_manager" {
|
|
count = var.manager_count
|
|
name = "${local.managers[count.index].name}.local"
|
|
groups = ["${var.swarm_name}_manager", var.swarm_name]
|
|
}
|
|
|
|
resource "ansible_host" "swarm_worker" {
|
|
count = var.worker_count
|
|
name = "${local.workers[count.index].name}.local"
|
|
groups = ["${var.swarm_name}_worker", var.swarm_name]
|
|
}
|