provider "proxmox" { endpoint = var.proxmox_server api_token = var.proxmox_apikey ssh { agent = true username = var.proxmox_username_ssh socks5_server = var.proxmox_server_ssh password = var.proxmox_password_ssh node { name = "fenix" address = "127.0.0.1" port = 1081 } } } resource "proxmox_virtual_environment_download_file" "latest_ubunto_cloud_img" { content_type = "iso" datastore_id = "local" node_name = "fenix" url = "https://cloud-images.ubuntu.com/jammy/20250725/jammy-server-cloudimg-amd64.img" file_name = "jammyservercloudimgamd64.img" } resource "proxmox_virtual_environment_vm" "proxmox-kubernetes-VM-template" { depends_on = [proxmox_virtual_environment_download_file.latest_ubunto_cloud_img] 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 = "scsi1" size = 64 } disk { datastore_id = "local-lvm" file_id = proxmox_virtual_environment_download_file.latest_ubunto_cloud_img.id interface = "scsi0" file_format = "qcow2" } # Configuração da interface de rede network_device { bridge = "vmbr0" model = "virtio" } initialization { ip_config { ipv4 { address = "dhcp" # IP estático + máscara de rede } } user_account { password = "testepassword" username = "testeuser" } } } resource "proxmox_virtual_environment_vm" "VM-Kubernetes-01" { depends_on = [proxmox_virtual_environment_vm.proxmox-kubernetes-VM-template] name = "VM-Kubernetes-01" node_name = "fenix" clone { vm_id = proxmox_virtual_environment_vm.proxmox-kubernetes-VM-template.id } agent { enabled = true } }