From a9a688ccd61dccc0de0f67ec052e40e76d3853d1 Mon Sep 17 00:00:00 2001 From: alfredo cedeno Date: Thu, 25 Jul 2024 19:36:17 +1000 Subject: [PATCH 1/2] adding packer code for ubuntu 24.04 --- .../ubuntu-server-noble/files/99-pve.cfg | 1 + .../ubuntu-server-noble/http/meta-data | 1 + .../ubuntu-server-noble/http/user-data | 33 +++++ .../ubuntu-server-noble.pkr.hcl | 140 ++++++++++++++++++ 4 files changed, 175 insertions(+) create mode 100644 packer/proxmox/ubuntu-server-noble/files/99-pve.cfg create mode 100644 packer/proxmox/ubuntu-server-noble/http/meta-data create mode 100644 packer/proxmox/ubuntu-server-noble/http/user-data create mode 100644 packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl diff --git a/packer/proxmox/ubuntu-server-noble/files/99-pve.cfg b/packer/proxmox/ubuntu-server-noble/files/99-pve.cfg new file mode 100644 index 0000000..e5477bc --- /dev/null +++ b/packer/proxmox/ubuntu-server-noble/files/99-pve.cfg @@ -0,0 +1 @@ +datasource_list: [ConfigDrive, NoCloud] diff --git a/packer/proxmox/ubuntu-server-noble/http/meta-data b/packer/proxmox/ubuntu-server-noble/http/meta-data new file mode 100644 index 0000000..8b13789 --- /dev/null +++ b/packer/proxmox/ubuntu-server-noble/http/meta-data @@ -0,0 +1 @@ + diff --git a/packer/proxmox/ubuntu-server-noble/http/user-data b/packer/proxmox/ubuntu-server-noble/http/user-data new file mode 100644 index 0000000..de3248e --- /dev/null +++ b/packer/proxmox/ubuntu-server-noble/http/user-data @@ -0,0 +1,33 @@ +#cloud-config +autoinstall: + version: 1 + locale: en_US + keyboard: + layout: de + ssh: + install-server: true + allow-pw: true + disable_root: true + ssh_quiet_keygen: true + allow_public_ssh_keys: true + packages: + - qemu-guest-agent + - sudo + storage: + layout: + name: direct + swap: + size: 0 + user-data: + package_upgrade: false + timezone: Europe/Berlin + users: + - name: your-user-name + groups: [adm, sudo] + lock-passwd: false + sudo: ALL=(ALL) NOPASSWD:ALL + shell: /bin/bash + # passwd: your-password + # - or - + # ssh_authorized_keys: + # - your-ssh-key diff --git a/packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl b/packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl new file mode 100644 index 0000000..b2c5e75 --- /dev/null +++ b/packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl @@ -0,0 +1,140 @@ +# Ubuntu Server Focal +# --- +# Packer Template to create an Ubuntu Server (Focal) on Proxmox + +# Variable Definitions +variable "proxmox_api_url" { + type = string +} + +variable "proxmox_api_token_id" { + type = string +} + +variable "proxmox_api_token_secret" { + type = string + sensitive = true +} + +# Resource Definiation for the VM Template +source "proxmox-iso" "ubuntu-server-noble" { + + # Proxmox Connection Settings + proxmox_url = "${var.proxmox_api_url}" + username = "${var.proxmox_api_token_id}" + token = "${var.proxmox_api_token_secret}" + # (Optional) Skip TLS Verification + # insecure_skip_tls_verify = true + + # VM General Settings + node = "your-proxmox-node" + vm_id = "100" + vm_name = "ubuntu-server-noble" + template_description = "Ubuntu Server Noble Image" + + # VM OS Settings + # (Option 1) Local ISO File + # iso_file = "local:iso/ubuntu-24.04-live-server-amd64.iso" + # - or - + # (Option 2) Download ISO + # iso_url = "https://releases.ubuntu.com/24.04/ubuntu-24.04-live-server-amd64.iso" + # iso_checksum = "8762f7e74e4d64d72fceb5f70682e6b069932deedb4949c6975d0f0fe0a91be3" + iso_storage_pool = "local" + unmount_iso = true + + # VM System Settings + qemu_agent = true + + # VM Hard Disk Settings + scsi_controller = "virtio-scsi-pci" + + disks { + disk_size = "20G" + format = "raw" + storage_pool = "local-lvm" + storage_pool_type = "lvm" + type = "virtio" + } + + # VM CPU Settings + cores = "1" + + # VM Memory Settings + memory = "2048" + + # VM Network Settings + network_adapters { + model = "virtio" + bridge = "vmbr0" + firewall = "false" + } + + # VM Cloud-Init Settings + cloud_init = true + cloud_init_storage_pool = "local-lvm" + + # PACKER Boot Commands + boot_command = [ + "c", + "linux /casper/vmlinuz --- autoinstall ds=\"nocloud-net;seedfrom=http://{{.HTTPIP}}:{{.HTTPPort}}/\"", + "", + "initrd /casper/initrd", + "", + "boot",""] + + boot_wait = "10s" + + # PACKER Autoinstall Settings + http_directory = "http" + # (Optional) Bind IP Address and Port + # http_bind_address = "0.0.0.0" + # http_port_min = 8802 + # http_port_max = 8802 + + ssh_username = "your-user-name" + + # (Option 1) Add your Password here + # ssh_password = "your-password" + # - or - + # (Option 2) Add your Private SSH KEY file here + # ssh_private_key_file = "~/.ssh/id_rsa" + + # Raise the timeout, when installation takes longer + ssh_timeout = "20m" +} + +# Build Definition to create the VM Template +build { + + name = "ubuntu-server-noble" + sources = ["source.proxmox-iso.ubuntu-server-noble"] + + # Provisioning the VM Template for Cloud-Init Integration in Proxmox #1 + provisioner "shell" { + inline = [ + "while [ ! -f /var/lib/cloud/instance/boot-finished ]; do echo 'Waiting for cloud-init...'; sleep 1; done", + "sudo rm /etc/ssh/ssh_host_*", + "sudo truncate -s 0 /etc/machine-id", + "sudo apt-get -y autoremove --purge", + "sudo apt-get -y clean", + "sudo apt-get -y autoclean", + "sudo cloud-init clean", + "sudo rm -f /etc/cloud/cloud.cfg.d/subiquity-disable-cloudinit-networking.cfg", + "sudo sync" + ] + } + + # Provisioning the VM Template for Cloud-Init Integration in Proxmox #2 + provisioner "file" { + source = "files/99-pve.cfg" + destination = "/tmp/99-pve.cfg" + } + + # Provisioning the VM Template for Cloud-Init Integration in Proxmox #3 + provisioner "shell" { + inline = [ "sudo cp /tmp/99-pve.cfg /etc/cloud/cloud.cfg.d/99-pve.cfg" ] + } + + # Add additional provisioning scripts here + # ... +} From 865ea5db0ee3286f85a219836e25215e0110f8d4 Mon Sep 17 00:00:00 2001 From: Christian Lempa Date: Mon, 2 Sep 2024 09:36:18 +0200 Subject: [PATCH 2/2] fix boot command and other small improvements --- .../ubuntu-server-noble.pkr.hcl | 45 ++++++++++--------- 1 file changed, 25 insertions(+), 20 deletions(-) diff --git a/packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl b/packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl index b2c5e75..86fa28c 100644 --- a/packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl +++ b/packer/proxmox/ubuntu-server-noble/ubuntu-server-noble.pkr.hcl @@ -1,6 +1,6 @@ -# Ubuntu Server Focal +# Ubuntu Server Noble (24.04.x) # --- -# Packer Template to create an Ubuntu Server (Focal) on Proxmox +# Packer Template to create an Ubuntu Server (Noble 24.04.x) on Proxmox # Variable Definitions variable "proxmox_api_url" { @@ -75,32 +75,36 @@ source "proxmox-iso" "ubuntu-server-noble" { # PACKER Boot Commands boot_command = [ - "c", - "linux /casper/vmlinuz --- autoinstall ds=\"nocloud-net;seedfrom=http://{{.HTTPIP}}:{{.HTTPPort}}/\"", - "", - "initrd /casper/initrd", - "", - "boot",""] + "", + "e", + "", + "", + "autoinstall ds=nocloud-net\\;s=http://{{ .HTTPIP }}:{{ .HTTPPort }}/ ---", + "" + ] - boot_wait = "10s" + boot = "c" + boot_wait = "10s" + communicator = "ssh" # PACKER Autoinstall Settings - http_directory = "http" + http_directory = "http" # (Optional) Bind IP Address and Port - # http_bind_address = "0.0.0.0" - # http_port_min = 8802 - # http_port_max = 8802 + # http_bind_address = "0.0.0.0" + # http_port_min = 8802 + # http_port_max = 8802 - ssh_username = "your-user-name" + ssh_username = "your-user-name" # (Option 1) Add your Password here - # ssh_password = "your-password" + # ssh_password = "your-password" # - or - # (Option 2) Add your Private SSH KEY file here - # ssh_private_key_file = "~/.ssh/id_rsa" + # ssh_private_key_file = "~/.ssh/id_rsa" # Raise the timeout, when installation takes longer - ssh_timeout = "20m" + ssh_timeout = "30m" + ssh_pty = true } # Build Definition to create the VM Template @@ -115,11 +119,12 @@ build { "while [ ! -f /var/lib/cloud/instance/boot-finished ]; do echo 'Waiting for cloud-init...'; sleep 1; done", "sudo rm /etc/ssh/ssh_host_*", "sudo truncate -s 0 /etc/machine-id", - "sudo apt-get -y autoremove --purge", - "sudo apt-get -y clean", - "sudo apt-get -y autoclean", + "sudo apt -y autoremove --purge", + "sudo apt -y clean", + "sudo apt -y autoclean", "sudo cloud-init clean", "sudo rm -f /etc/cloud/cloud.cfg.d/subiquity-disable-cloudinit-networking.cfg", + "sudo rm -f /etc/netplan/00-installer-config.yaml", "sudo sync" ] }