Xen Dom0: Difference between revisions
| mNo edit summary |  (Add section about increasing loop-devices) | ||
| Line 61: | Line 61: | ||
| Also remember to configure at least one network bridge following the [[Bridge]] guide. | Also remember to configure at least one network bridge following the [[Bridge]] guide. | ||
| == Loop Devices == | |||
| If you plan to use more than 8 DomU's, you may need to increase the amount of loop-devices in your Dom0. | |||
| In Alpine Linux, you will need to add the ''max_loop'' option to the ''loop'' module, then add the loop module to your initramfs. | |||
| Start by populating <code>/etc/modprobe.d/loop.conf</code> with the module options: | |||
| <pre> | |||
| # touch /etc/modprobe.d/loop.conf | |||
| # echo "options loop max_loop=32" > /etc/modprobe.d/loop.conf | |||
| </pre> | |||
| Now reflect the module options in the initramfs: | |||
| <pre> | |||
| # mkinitfs | |||
| # reboot | |||
| </pre> | |||
| == See also == | == See also == | ||
Revision as of 14:32, 6 August 2019
This guide will show you how to perform a Xen Dom0 install on a HDD, so you can have your Dom0. The first step is to perform a normal HDD install of Alpine Linux, which can be accomplished following the guide Install to disk. Once the install is finished, and you have rebooted into your new system, it's time to install the Xen packages:
# apk add xen xen-hypervisor seabios
Then enable the community repositories and install ovmf from community.
# apk add ovmf
seabios and ovmf provide BIOS and UEFI firmwares for Xen virtual machines. Please be advised that ovmf is part of the community repository. In order to download it, you will need to add the community repository to your configuration.
This will install Xen Hypervisor, xl cli command and all the required packages. The next step is to modify your extlinux.cfg and add an entry to boot Xen:
Normal boot:
LABEL xen KERNEL /boot/mboot.c32 APPEND /boot/xen.gz --- /boot/grsec root=UUID=<YOUR-DISK-UUID> modules=ext4 --- /boot/grsec.gz
Serial console boot:
LABEL xen KERNEL /boot/mboot.c32 APPEND /boot/xen.gz com1=115200,8n1 console=com1 --- /boot/grsec root=UUID=<YOUR-DISK-UUID> modules=ext4 --- /boot/grsec.gz
com1=115200,8n1 console=com1 redirect xen and dom0 to a physical serial port, handy if you want to use a serial null modem cable instead of a keyboard+monitor combo or if your server has an kvm over ip.
It's also a good idea to check Xen Boot options and set dom0_mem, dom0_vcpus_pin and dom0_max_vcpus at least.
The next step is to load the necessary kernel modules for Xen, we will add them to /etc/modules, so they will be loaded automatically on boot:
# echo "xen_netback" >> /etc/modules # echo "xen_blkback" >> /etc/modules # echo "tun" >> /etc/modules
The last step is to configure startup services, we will need udev and xencommons at least to be started on boot:
rc-update add xenconsoled rc-update add xendomains rc-update add xenqemu rc-update add xenstored
Ok, now you have a fully functional Xen install, it's time to boot into it.
# reboot
Also remember to configure at least one network bridge following the Bridge guide.
Loop Devices
If you plan to use more than 8 DomU's, you may need to increase the amount of loop-devices in your Dom0.
In Alpine Linux, you will need to add the max_loop option to the loop module, then add the loop module to your initramfs.
Start by populating /etc/modprobe.d/loop.conf with the module options:
# touch /etc/modprobe.d/loop.conf # echo "options loop max_loop=32" > /etc/modprobe.d/loop.conf
Now reflect the module options in the initramfs:
# mkinitfs # reboot