166 lines
4.2 KiB
HCL
166 lines
4.2 KiB
HCL
# Rocky Linux 9 Server
|
|
# ---
|
|
# Packer Template to create an Rocky Linux 9 Server on Proxmox
|
|
packer {
|
|
required_plugins {
|
|
proxmox = {
|
|
version = ">= 1.1.3"
|
|
source = "github.com/hashicorp/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
|
|
}
|
|
|
|
variable "proxmox_ssh_username" {
|
|
type = string
|
|
sensitive = true
|
|
}
|
|
|
|
variable "proxmox_ssh_password" {
|
|
type = string
|
|
sensitive = true
|
|
}
|
|
|
|
|
|
source "proxmox-iso" "rocky-linux-8" {
|
|
|
|
# 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 = "boba"
|
|
vm_id = "4800"
|
|
vm_name = "rocky-linux-8"
|
|
template_description = "Rocky Linux 8 Server Image"
|
|
machine = "q35"
|
|
bios = "ovmf"
|
|
os = "l26"
|
|
|
|
efi_config {
|
|
efi_storage_pool = "fast"
|
|
}
|
|
|
|
# VM OS Settings
|
|
# (Option 1) Local ISO File
|
|
# iso_file = "local:iso/ubuntu-20.04.2-live-server-amd64.iso"
|
|
# - or -
|
|
# (Option 2) Download ISO
|
|
# iso_url = "https://releases.ubuntu.com/20.04/ubuntu-20.04.3-live-server-amd64.iso"
|
|
# iso_checksum = "f8e3086f3cea0fb3fefb29937ab5ed9d19e767079633960ccb50e76153effc98"
|
|
iso_file = "data:iso/rocky-8.8-x86_64-dvd1.iso"
|
|
iso_storage_pool = "data"
|
|
unmount_iso = true
|
|
|
|
# VM System Settings
|
|
qemu_agent = true
|
|
|
|
# VM Hard Disk Settings
|
|
scsi_controller = "virtio-scsi-pci"
|
|
|
|
disks {
|
|
disk_size = "40G"
|
|
format = "raw"
|
|
storage_pool = "fast"
|
|
type = "virtio"
|
|
}
|
|
|
|
# VM CPU Settings
|
|
cores = "2"
|
|
cpu_type = "host"
|
|
|
|
# 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 = "fast"
|
|
|
|
# PACKER Boot Commands
|
|
boot_command = ["e<down><down><end><bs><bs><bs><bs><bs>inst.text inst.ks=http://{{ .HTTPIP }}:{{ .HTTPPort }}/kickstart.cfg<leftCtrlOn>x<leftCtrlOff>"]
|
|
boot_wait = "5s"
|
|
|
|
# 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 = "${var.proxmox_ssh_username}"
|
|
|
|
# (Option 1) Add your Password here
|
|
ssh_password = "${var.proxmox_ssh_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 = "rocky-linux-8"
|
|
sources = ["source.proxmox-iso.rocky-linux-8"]
|
|
|
|
# Provisioning the VM Template for Cloud-Init Integration in Proxmox #1
|
|
provisioner "shell" {
|
|
inline = [
|
|
"echo 'Updating system...'",
|
|
"dnf -y update",
|
|
"dnf install -y cloud-init qemu-guest-agent cloud-utils-growpart gdisk",
|
|
"systemctl enable qemu-guest-agent",
|
|
"echo 'manual_cache_clean: True' > /etc/cloud/cloud.cfg.d/99-manual.cfg",
|
|
"shred -u /etc/ssh/*_key /etc/ssh/*_key.pub",
|
|
"rm -f /var/run/utmp",
|
|
">/var/log/lastlog",
|
|
">/var/log/wtmp",
|
|
">/var/log/btmp",
|
|
"rm -rf /tmp/* /var/tmp/*",
|
|
"unset HISTFILE; rm -rf /home/*/.*history /root/.*history",
|
|
"rm -f /root/*ks",
|
|
"passwd -d root",
|
|
"passwd -l root",
|
|
"rm -f /etc/ssh/ssh_config.d/allow-root-ssh.conf"
|
|
]
|
|
}
|
|
|
|
# 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
|
|
# ...
|
|
} |