Proxmox Debian VM mit Ansible und Cloudinit Provisionieren
Beschreibung:
Ein Playbook zum erstellen einer Debian 11 VM per Ansible.
---
- name: Erstelle eine VM auf Proxmox
hosts: localhost
gather_facts: no
tasks:
- name: Lade Debian 11 Cloud-Image herunter
ansible.builtin.get_url:
url: "https://cloud.debian.org/images/cloud/bullseye/latest/debian-11-generic-amd64.qcow2"
dest: "/tmp/debian-11-cloud-image.qcow2"
mode: '0644'
- name: Ermittle die nächste freie VMID
community.general.proxmox_nextid:
api_user: "{{ prox_api_user }}"
api_password: "{{ prox_api_password }}"
api_host: "{{ prox_api_host }}"
register: next_vmid
when: vmvar_vmid is not defined
- name: Setze die VMID
set_fact:
vmid: "{{ vmvar_vmid if vmvar_vmid is defined else next_vmid.nextid }}"
- name: Verschiebe Cloud-Image in den VM-Speicherbereich
ansible.builtin.shell: "mv /tmp/debian-11-cloud-image.qcow2 /var/lib/vz/images/{{ vmid }}/vm-{{ vmid }}-disk-0.qcow2"
become: yes
- name: Erstelle VM
community.general.proxmox:
api_user: "{{ prox_api_user }}"
api_password: "{{ prox_api_password }}"
api_host: "{{ prox_api_host }}"
node: "{{ prox_node }}"
ostype: "{{ vmvar_ostype }}"
disk: "virtio,size={{ vmvar_disk_size }}"
cores: "{{ vmvar_cores }}"
memory: "{{ vmvar_memory }}"
net: '{"net0":"virtio,bridge={{ vmvar_vmbr }}"}'
virtio: '{"virtio0":"local:{{ vmid }}/vm-{{ vmid }}-disk-0.qcow2,size={{ vmvar_disk_size }}"}'
ciuser: "root"
name: "{{ inventory_hostname }}"
ipconfig0: "ip={{ vmvar_ip_address }}/24,gw={{ vmvar_gw }}"
cipassword: "{{ vmvar_root_password }}"
sshkeys: "{{ vmvar_public_key }}"
nameserver: "{{ vmvar_dns }}"
searchdomain: "{{ vmvar_searchdomain }}"
custom_preseed: "{{ lookup('file', 'preseed.cfg') }}"
state: "present"
force: yes
vmid: "{{ vmid }}"
register: vm_result
- name: Warte auf VM-Start
pause:
seconds: 30
- name: VM-Details
debug:
var: vm_result
Die Hilfe zu den Parametern
- vmvar_vmid (optional): Die eindeutige ID der VM innerhalb des Proxmox-Clusters (Beispiel: 100). Wenn dieser Parameter nicht angegeben ist, wird automatisch die nächste freie VMID ermittelt.
- vmvar_disk_size: Größe der Festplatte für die VM (z. B. 64G für 64 GB).
- vmvar_root_password: Passwort für den Root-Benutzer der VM (Beispiel: your_root_password).
- vmvar_public_key: Der öffentliche SSH-Schlüssel, der für den Root-Benutzer der VM hinzugefügt wird (Beispiel: "your_ssh_public_key").
- vmvar_ip_address: Die IP-Adresse, die der VM zugewiesen wird (Beispiel: 192.168.178.121).
- vmvar_cores: Die Anzahl der CPU-Kerne, die der VM zugewiesen wird (Beispiel: 2).
- vmvar_memory: Die Menge an Arbeitsspeicher (RAM) in Megabyte, die der VM zugewiesen wird (Beispiel: 2048).
- vmvar_vmbr: Die Netzwerkbrücke, an die die VM angeschlossen wird (Beispiel: vmbr0).
- vmvar_gw: Das Gateway, das für die VM verwendet wird (Beispiel: 192.168.178.1).
- vmvar_dns: Der DNS-Server, der für die VM verwendet wird (Beispiel: 8.8.8.8).
- vmvar_searchdomain: Die Searchdomain, die für die VM verwendet wird (Beispiel: example.com).
- prox_api_host: Die IP-Adresse des Proxmox-Hosts (Beispiel: 192.168.178.120).
- prox_api_user: Der Benutzername für die Anmeldung am Proxmox-Host (z. B. root@pam).
- prox_api_password: Das Passwort für den Proxmox-Benutzer (Beispiel: 12345678).
- prox_node: Der Proxmox-Node, auf dem die VM erstellt werden soll (Beispiel: pve).
- vmvar_ostype: Der Betriebssystemtyp der VM (Beispiel: l26).
Liste der OS-Typen:
- l26: Linux 2.6/3.x/4.x/5.x Kernel
- other: Anderes OS
- wxp: Windows XP
- w2k: Windows 2000
- w2k3: Windows 2003
- w2k8: Windows 2008
- wvista: Windows Vista
- win7: Windows 7
- win8: Windows 8/2012
- win10: Windows 10/2016/2019
Beispiel einer Inventory Datei
[vm]
vm1 ansible_host=192.168.178.121 vmvar_vmid=100 vmvar_disk_size=64G vmvar_root_password=your_root_password vmvar_public_key="your_ssh_public_key" vmvar_ip_address=192.168.178.121 vmvar_cores=2 vmvar_memory=2048 vmvar_vmbr=vmbr0 vmvar_gw=192.168.178.1 vmvar_dns=8.8.8.8 vmvar_searchdomain=example.com prox_api_host=192.168.178.120 prox_api_user=root@pam prox_api_password=12345678 prox_node=pve vmvar_ostype=l26