Making it easier to install VMs on XCP
Installing a linux VM on XCP requires the following steps:
- Clone a template
- Add a CDROM or a VIF
- Tweak some VM.other_config:parameters (e.g. to include the exact URL of an install repo)
- Answer the VM installer's questions
Ideally we would have
- Fewer steps (more sensible defaults)
- More tolerance to user error (e.g. if the network URL isn't perfect, use a heuristic to find the install files)
Ideas for improvement
- Add a VIF to our default templates to the main management network. This would make network installation easier.
- If no network install URL is provided, fall back to a known good one
- Even better would be to use a tool like Debian netselect to choose a good one
- If a network install URL is provided but it slightly wrong (typical failure would be to point at a subdirectory by mistake), attempt to auto-correct it
- If a CDROM is attached, attempt to detect the install files and work out what kind of system it is (debianlike or rhlike)
- Allow the user to request an auto-install via an answerfile or preseed file
- Even better would be to serve-up default answerfiles from the system
- Getting away from eliloader
Some operating systems (Debian Lenny/Squeeze/Wheezy, Ubuntu ~L,M,N,O, OpenSuse) can be easily installed via pre-shipped initrd (netinst) and kernel. This will:
- Reduce all operations with other-config:install-repository
- Allow to install operating systems without internet connectivity between dom0 and internet (note: guests can have it, but dom0 no more), this will make isolation of management network more reliable (Someone ether though about attack on dom0 via bad initrd, f.e. very big to eat all dom0 disk space?).
- Simplify steps to start VM
- elilo can be used for other templates (like older rhel with initrd patching).
- Allow local console for PV-guests.
When user make xe vm-start for initially created vm from special template, we can do following:
- disable vnc console for initial startup (one time)
- run VM on host where command was entered (will not work with remove xe)
- do xl console for VM domain.
User expirience will be very nice: xe vm-install template=BoBoBo, xe vm-start, and user got console of installing virtial machine.
Measuring the improvements
- Count the number of characters you need to type to install a particular guest type (eg Debian 6.0). Lower is better.