Xen Project Best Practices
- 1 Best Practices for Xen Project
- 1.1 Paravirtualization (PV) or (hardware-assisted virtualization) HVM
- 1.2 Xen Project dom0 dedicated memory and preventing dom0 memory ballooning
- 1.3 Why should I dedicate fixed amount of memory for Xen Project dom0?
- 1.4 Xen Project credit scheduler domain weights and making sure dom0 gets enough CPU time to serve IO requests (disk/net)
- 1.5 Dedicating a CPU core(s) only for dom0
- 1.6 dom0 network configuration
- 1.7 Common problems with Xen Project
Best Practices for Xen Project
This wiki page lists various best practices for running Xen Project hypervisor.
Information here applies to opensource Xen Project software from XenProject.org, not necessarily to XenServer or XCP.
Paravirtualization (PV) or (hardware-assisted virtualization) HVM
Paravirtualization used to be the recommended choice, because it required no hardware support and less emulation of things like interrupt, disk and network controllers, and could run on any CPU. But with PVHVM (hardware-assisted virtualization with paravirtualized drivers in the guest), the (already diminishing) advantages don't outweigh the disadvantages (more difficult management such as OS bootstrapping), and also Spectre and Meltdown security. As can be read in XEN PROJECT SPECTRE / MELTDOWN FAQ (JAN 22 UPDATE), a strategy to combat Meltdown that does not require a non-standard release of Xen, involves switching to HVM.
Xen Project dom0 dedicated memory and preventing dom0 memory ballooning
You should always dedicate a fixed amount of RAM for Xen Project dom0. To plan what you need, you need to take into account what you may run in your dom0 (
rsync processes for backups,
partclone or similar tools for DomU imaging, etc), but also a QEMU device model per HVM guest. 1024 MB is a good starting point, but if you run dozens of DomU's, you may need more.
This can be done by specifying "
dom0_mem=1024M,max:1024M" for the Xen Project hypervisor (usually
xen.gz) in the
/boot/grub/menu.lst file. This makes sure that the initial amount of memory allocated for dom0 is 1024 MB (note: Replace this value with the amount of memory you want to allocate to dom0) and leaves the rest of the host system's RAM available for other guests.
title Xen 4.1.0 / pv_ops dom0 kernel 126.96.36.199 root (hd0,0) kernel /xen-4.0.gz dom0_mem=1024M,max:1024M loglvl=all guest_loglvl=all module /vmlinuz-188.8.131.52 ro root=/dev/sda2 console=hvc0 earlyprintk=xen nomodeset module /initrd-184.108.40.206.img
Add or edit the following line in the
The next step is to configure the toolstack to make sure dom0 memory is never ballooned down while starting new guests:
- If you are using the XL toolstack this can be done by editing
autoballoon=0. This will prevent XL from ever automatically adjusting the amount of memory assigned to dom0.
- If you are using the xend toolstack this can be done by editing
/etc/xen/xend-config.sxpand changing the "
dom0-min-mem" option (to "
dom0-min-mem 1024") and changing the "
enable-dom0-ballooning" option (to "
enable-dom0-ballooning no"). These options will make sure
xendnever takes any memory away from dom0.
After making these changes to
grub.conf and to
xend-config.sxp/xl.conf, reboot the system. After reboot you will notice dom0 has only 1204 MB of memory, and the rest of the RAM is available in Xen hypervisor as a free memory. You can run "
xl list" (or "
xm list") to verify the amount of memory dom0 has, and "
xl info" (or "
xm info") to verify the amount of free memory in Xen Project hypervisor.
Why should I dedicate fixed amount of memory for Xen Project dom0?
Dedicating fixed amount of memory for dom0 is good for two reasons:
First of all (dom0) Linux kernel calculates various network related parameters based on the boot time amount of memory.
The second reason is Linux needs memory to store the memory metadata (per page info structures), and this allocation is also based on the boot time amount of memory.
Now, if you boot up the system with dom0 having all the memory visible to it, and then balloon down dom0 memory every time you start up a new guest, you end up having only a small amount of the original (boot time) amount of memory available in the dom0 in the end. This means the calculated parameters are not correct anymore, and you end up wasting a lot of memory for the metadata for a memory you don't have anymore. Also ballooning down busy dom0 might have bad side effects.
Xen Project credit scheduler domain weights and making sure dom0 gets enough CPU time to serve IO requests (disk/net)
For smooth operation and good guest performance you need to make sure that dom0 always gets enough CPU time to process and serve the IO requests for guest VMs. This can be done by setting up the Xen Project credit scheduler domain weights and caps. See CreditScheduler wiki page for more information.
Some background: As a default Xen Project gives every guest (including dom0) the default weight of 256. This means all guests (including dom0) are equal, and get the same amount of CPU time. This can be bad for dom0, since it needs to be able to serve and process the IO requests for other guests. You should give dom0 more weight, so it will get more CPU time than the guests, when it needs it.
- use "
xm sched-credit -d Domain-0" to check the current Xen Project credit scheduler parameters for dom0.
- use "
xm sched-credit -d Domain-0 -w 512" to give dom0 weight of 512, giving it more (up to twice as much) CPU time than the guests.
Note that you need to apply this setting after every reboot! It's not a persistent setting. You can place the "
xm sched-credit" command in
rc.local or another script that is executed late in the boot process. Make sure the command is executed after
xend is started, since the
xm command needs to talk to
For domUs just use the default weight (256), unless you have a reason to tweak them.
Dedicating a CPU core(s) only for dom0
If you're running IO intensive guests or workloads in the VMs it might be a good idea to dedicate (pin) a CPU core only for dom0 use. Please see XenCommonProblems wiki page section "Can I dedicate a cpu core (or cores) only for dom0?" for more information.
dom0 network configuration
You should configure and set up networking on Xen Project dom0 using the networking scripts provided by your dom0 distribution (i.e., "
/etc/network/interfaces" on Debian and Ubuntu, and "
/etc/sysconfig/network-scripts/ifcfg*" on RHEL/CentOS/Fedora). Using the networking scripts provided by your dom0 is much better than using the Xen "
network-bridge" script, which is troublesome on many configurations due to renaming tricks it uses.
If using XL / LIBXL toolstack (Xen Project 4.1+) you're actually required to set up the networking using distro network scripts!
To use distro networking scripts/tools:
- If using xm/xend toolstack disable the Xen Project network-script in "
/etc/xen/xend-config.sxp", i.e., comment out the "
network-script" line, or make it be "
- Configure network settings (bridges, VLANs, etc.) using the networking scripts available on your dom0 distribution. See the documentation of your distro for more help.
You can still use the default Xen Project vif-bridge script to attach VM vifs to the bridges you have configured using the distro networking tools so that no changes are required to the domU configuration files in "
See Network Configuration Examples (Xen 4.1+) wiki page for examples how to use the distro network scripts.
Common problems with Xen Project
Also check the XenCommonProblems wiki page for answers to many common problems related to using/running Xen Project software.
|Language:||English • Deutsch • español • français • 日本語 • 한국어 • português do Brasil • русский • 中文|