Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/clayshek/ans-pve-win-provision
Use Ansible to provision new Proxmox Windows VMs from template
https://github.com/clayshek/ans-pve-win-provision
ansible homelab provisioning proxmox windows
Last synced: 2 months ago
JSON representation
Use Ansible to provision new Proxmox Windows VMs from template
- Host: GitHub
- URL: https://github.com/clayshek/ans-pve-win-provision
- Owner: clayshek
- Created: 2020-07-14T00:38:06.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-07-14T00:44:22.000Z (over 4 years ago)
- Last Synced: 2024-08-13T07:16:16.035Z (5 months ago)
- Topics: ansible, homelab, provisioning, proxmox, windows
- Language: Smarty
- Homepage:
- Size: 13.7 KB
- Stars: 5
- Watchers: 1
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- jimsghstars - clayshek/ans-pve-win-provision - Use Ansible to provision new Proxmox Windows VMs from template (Smarty)
README
# ans-pve-win-provision
## Summary
Ansible playbook to provision new Windows VM(s), cloned off of an existing template on a [Proxmox](https://www.proxmox.com/en/proxmox-ve) hypervisor. Mostly custom to my lab environment, but easy enough to modify.
As exists currently in this repo, will create the following new VMs in Proxmox:
- DC01 & DC02 (base VMs for Active Directory Domain Controllers)
- SCVMM01 (base VM for System Center Virtual Machine Manager)
- WAC01 (base VM for Windows Admin Center)
- HVH01, HVH02, HVH03, HVH04 (base VMs for Hyper-V Hypervisor nodes, requires Proxmox nested virtualization)This allows for per-VM customization of parameters such as name, IP, CPU, RAM, admin password, and adding an additional data drive.
End result will be running VM(s) based off of specified template, which are ready to be further customized (domain join, role/feature and application installation) - see https://github.com/clayshek/ansible-lab-config
## Usage & Requirements
- Requires a Windows template to already exist (see https://github.com/clayshek/ans-pve-win-templ)
- Modify inventory.yml if necessary. Any new hosts will need to have a hostname.yml variables file created in host_vars/
- Modify variables in group_vars and host_vars as necessary. Consider [Ansible Vault](https://docs.ansible.com/ansible/latest/user_guide/vault.html) for passwords / sensitive variables.
- Fail / Retry logic added to account for per-node file locks, and is expected (see To-Do section)`ansible-playbook -i inventory.yml --ask-vault-pass provision-base-vms.yml`
- Or to limit to a specific host or host group:
`ansible-playbook -i inventory.yml -l [HOST|HOSTGROUP] --ask-vault-pass provision-base-vms.yml`
Once VM / OS provisioning complete, detach and delete the ISO created with the unattend.xml file (this will have cleartext administrator credentials).
## To-Do
- [ ] Add functionality to detach CDROM from VM and delete unattend ISO when provisioning complete
- [ ] Possibly change VM creation to run serially as opposed to parallel to prevent file locks## Disclaimer
Primary purpose is to quickly provision base VMs for a Windows infrastructure lab environment on top of Proxmox. Security best practices not always a top priority.