Files
iac-opentofu-public/proxmox.tf
2025-08-20 19:36:38 +00:00

90 lines
2.0 KiB
HCL

provider "proxmox" {
endpoint = var.proxmox_server
api_token = var.proxmox_apikey
ssh {
agent = true
username = "terraform"
}
}
resource "proxmox_virtual_environment_download_file" "Fedora-iso" {
content_type = "iso" # tipo do arquivo
datastore_id = "local" # datastore do Proxmox onde o arquivo será guardado
node_name = "fenix" # nó do Proxmox onde será armazenado
file_name = "Fedora-Cloud-Base-41.qcow2"
url = "https://download.fedoraproject.org/pub/fedora/linux/releases/41/Cloud/x86_64/images/Fedora-Cloud-Base-41-1.4.x86_64.qcow2"
}
resource "proxmox_virtual_environment_vm" "proxmox-kubernetes-VM-template" {
depends_on = [proxmox_virtual_environment_download_file.Fedora-iso]
name = "proxmox-kubernetes-VM-template"
node_name = "fenix"
vm_id = 1002
template = true
started = false
agent {
enabled = true
}
tags = ["opentofu", "kubernetes", "fedora"]
machine = "q35"
bios = "seabios"
description = "kubernetes VM Template created via iac"
cpu {
cores = 2
}
memory {
dedicated = 4096
}
# Configuração do disco rígido
disk {
datastore_id = "local-lvm"
interface = "scsi0"
size = 64
}
disk {
datastore_id = "local-lvm"
interface = "scsii"
file_id = proxmox_virtual_environment_download_file.Fedora-iso.id
size = 20
}
# Configuração da interface de rede
network_device {
bridge = "vmbr0"
model = "virtio"
}
initialization {
ip_config {
ipv4 {
address = "192.168.1.24/24" # IP estático + máscara de rede
gateway = "192.168.1.1" # Gateway da rede
}
}
user_account {
password = "passexemplo"
username = "userexemplo"
}
}
}
resource "proxmox_virtual_environment_vm" "VM-Kubernetes-01" {
name = "VM-Kubernetes-01"
node_name = "fenix"
clone {
vm_id = proxmox_virtual_environment_vm.proxmox-kubernetes-VM-template.id
}
agent {
enabled = true
}
}