Compare commits

...

2 Commits

Author SHA1 Message Date
753d5c38e4 add package upgrades and output of VM IP 2025-03-21 21:57:26 +00:00
a39d0ceacb use env file for cloud-init 2025-03-21 21:09:50 +00:00
3 changed files with 52 additions and 64 deletions

View File

@ -1,99 +1,87 @@
data "proxmox_virtual_environment_vms" "template" {
filter {
name = "name"
values = ["ubuntu-cloud"]
}
name = "name"
values = ["ubuntu-cloud"]
}
}
# resource "proxmox_virtual_environment_file" "cloud_config" {
# content_type = "snippets"
# datastore_id = "local"
# node_name = "zenith"
# source_raw {
# data = <<-EOF
# #cloud-config
# hostname: simple-vm
# packages:
# - qemu-guest-agent
# users:
# - default
# - name: vez
# groups: sudo
# shell: /bin/bash
# ssh-authorized-keys:
# - "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAICxWxrBF6W6N2ZrzoKhTwDTZ49tlYzvki+4naHjo8DhB vez-key"
# sudo: ALL=(ALL) NOPASSWD:ALL
# EOF
# file_name = "example.cloud-config.yaml"
# }
# }
resource "proxmox_virtual_environment_file" "cloud_config" {
content_type = "snippets"
datastore_id = "local"
node_name = "zenith"
source_raw {
file_name = "simple_vm.cloud-config.yaml"
data = <<-EOF
#cloud-config
hostname: simple-vm
package_update: true
package_upgrade: true
packages:
- qemu-guest-agent
users:
- default
- name: vez
groups: sudo
shell: /bin/bash
ssh-authorized-keys:
- "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAID62LmYRu1rDUha3timAIcA39LtcIOny1iAgFLnxoBxm vez@bastion"
sudo: ALL=(ALL) NOPASSWD:ALL
runcmd:
- systemctl enable qemu-guest-agent
- reboot
EOF
}
}
resource "proxmox_virtual_environment_vm" "simple_vm" {
name = "simple-vm"
node_name = "zenith"
tags = ["test"]
agent {
enabled = false
enabled = true
}
# if agent is not enabled, the VM may not be able to shutdown properly, and may need to be forced off
stop_on_destroy = true
clone {
vm_id = data.proxmox_virtual_environment_vms.template.vms[0].vm_id
}
bios = "ovmf"
bios = "ovmf"
machine = "q35"
cpu {
cores = 2
type = "host"
type = "host"
}
memory {
dedicated = 2048
}
disk {
datastore_id = "ceph-workload"
#file_id = proxmox_virtual_environment_download_file.latest_ubuntu_22_jammy_qcow2_img.id
interface = "scsi0"
size = 4
interface = "scsi0"
size = 4
}
initialization {
datastore_id = "ceph-workload"
interface = "scsi1"
user_data_file_id = proxmox_virtual_environment_file.cloud_config.id
datastore_id = "ceph-workload"
interface = "scsi1"
ip_config {
ipv4 {
address = "dhcp"
}
}
user_account {
keys = ["ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAID62LmYRu1rDUha3timAIcA39LtcIOny1iAgFLnxoBxm vez@bastion"]
username = "vez"
}
#user_data_file_id = proxmox_virtual_environment_file.cloud_config.id
}
network_device {
bridge = "vmbr0"
bridge = "vmbr0"
vlan_id = 66
}
operating_system {
type = "l26"
}
vga {
type = "std"
}
}
output "vm_ip" {
value = proxmox_virtual_environment_vm.simple_vm.ipv4_addresses[1][0]
description = "VM IP"
}

View File

@ -1,18 +1,18 @@
terraform {
required_providers {
proxmox = {
source = "bpg/proxmox"
source = "bpg/proxmox"
}
}
}
provider "proxmox" {
endpoint = var.proxmox_endpoint
endpoint = var.proxmox_endpoint
api_token = var.proxmox_api_token
insecure = false
insecure = false
ssh {
agent = false
agent = false
private_key = file("~/.ssh/id_ed25519")
username = "root"
}
username = "root"
}
}

View File

@ -6,5 +6,5 @@ variable "proxmox_endpoint" {
variable "proxmox_api_token" {
description = "Proxmox API token"
type = string
sensitive = true
sensitive = true
}