Xen Dom0: Difference between revisions
(actually hyphens, not underscores) |
No edit summary |
||
Line 1: | Line 1: | ||
This guide will show you how to | This guide will show you how to have your 'sys' install of Alpine run as a Xen Dom0. You can start either from an existing standard install or install a new copy of Alpine with the Alpine Xen ISO. | ||
< | == Install Xen == | ||
=== New installation === | |||
</ | ==== Writing the medium ==== | ||
{{Warning|This will erase '''everything''' on the drive you point it at. Check and double check that <code>/dev/sdx</code> is the correct USB device you want to write to, using the commands <code>lsblk</code> and <code>blkid</code>.}} | |||
First download Alpine's [https://www.alpinelinux.org/downloads/ Xen install ISO], and either [[Burning ISOs|burn the ISO to a CD/DVD]] or write it to a USB storage device with the following command, where <code>3.12.0</code> should be replaced with the release number of your downloaded ISO and <code>/dev/sdx</code> should be replaced with the drive letter of your USB: | |||
<pre>dd if=alpine-xen-3.12.0-x86_64.iso of=/dev/sdx</pre> | |||
==== Installation ==== | |||
Now boot from your CD or USB, and type 'root' when prompted for a username. After you have logged in run <code>setup-xen-dom0</code>, then continue with a standard [[Install to disk|Alpine installation]] until you get to the prompt asking to choose your network card. | |||
What you'll want to do is select what is to be your internet-facing interface, and when asked to bridge it type 'yes'. Then you can configure the networking settings of your bridge device, <code>br0</code>, as you would have configured your internet-facing interface. | |||
{{Note|You cannot bridge a WiFi interface in the automatic installation script due to incompatible protocols. Make sure you pick an ethernet interface for this.}} | |||
Now continue with your installation to disk until you reach the 'reboot' prompt. There are a few more things to do before you can boot without errors: | |||
<pre> | <pre> | ||
# apk add | # xen-hypervisor isn't installed by default with Xen so we must install it manually | ||
apk add xen-hypervisor | |||
apk add bridge | |||
</pre> | </pre> | ||
Now you can safely reboot after removing your install medium, making sure to pick the <code>Alpine Linux v3.12, with Xen 4.13.1 and Linux lts</code> boot option in your GRUB menu, with 3.12 and 4.13.1 replaced with your Linux and Xen version numbers, respectively. | |||
After this, [[Enable Community Repository|enable the Alpine community repository]] and install the firmware to be used for Xen's virtual machines: | |||
<pre> | <pre> | ||
apk add seabios ovmf | |||
</pre> | </pre> | ||
Now you are ready to configure GRUB. | |||
=== Existing installation === | |||
First you must [[Enable Community Repository|enable the Alpine community repository]], then install Xen and the seabios (BIOS) and ovmf (UEFI) firmwares for its virtual machines. | |||
<pre> | <pre> | ||
# | # apk add xen xen-hypervisor seabios ovmf | ||
</pre> | </pre> | ||
The | This will install Xen Hypervisor, xl cli command and all the required packages. The next step is to modify your GRUB configuration to properly boot Xen. | ||
< | == GRUB configuration == | ||
Once running a Xen kernel we will need to edit its command-line options and enable the setting of a default GRUB entry by inserting this at the bottom of <code>/etc/default/grub</code>: | |||
{{Cat|/etc/default/grub|<nowiki># We need to set the amount of RAM we allocate to our Dom0 Alpine install so that | |||
# our future virtual machines are left with enough memory. | |||
GRUB_CMDLINE_XEN_DEFAULT="dom0_mem=1024M,max:1024M" | |||
GRUB_DEFAULT="saved" | |||
GRUB_SAVEDEFAULT="true"</nowiki>}} | |||
<pre> | You can replace 1024M with the amount of memory you want to allocate to your Dom0 operating system. | ||
After this you need to run the following: | |||
<pre>grub-mkconfig -o /boot/grub/grub.cfg | |||
grub-set-default "$(grep ^menuentry | grep Xen | cut -d \' -f 2 | head -1)" | |||
</pre> | </pre> | ||
What this does is set your default entry in GRUB to the first entry containing 'Xen'. Run this every time you upgrade Alpine or Xen. | |||
== Loop Devices == | == Loop Devices == | ||
Line 83: | Line 73: | ||
== See also == | == See also == | ||
* [[Xen Dom0 on USB or SD]] | * [[Xen Dom0 on USB or SD]] | ||
* [https://wiki.gentoo.org/wiki/Xen#Host_configuration_.28domain-0.29|Xen page on Gentoo wiki] | |||
[[Category:Virtualization]] | [[Category:Virtualization]] |
Revision as of 06:18, 27 August 2020
This guide will show you how to have your 'sys' install of Alpine run as a Xen Dom0. You can start either from an existing standard install or install a new copy of Alpine with the Alpine Xen ISO.
Install Xen
New installation
Writing the medium
/dev/sdx
is the correct USB device you want to write to, using the commands lsblk
and blkid
.
First download Alpine's Xen install ISO, and either burn the ISO to a CD/DVD or write it to a USB storage device with the following command, where 3.12.0
should be replaced with the release number of your downloaded ISO and /dev/sdx
should be replaced with the drive letter of your USB:
dd if=alpine-xen-3.12.0-x86_64.iso of=/dev/sdx
Installation
Now boot from your CD or USB, and type 'root' when prompted for a username. After you have logged in run setup-xen-dom0
, then continue with a standard Alpine installation until you get to the prompt asking to choose your network card.
What you'll want to do is select what is to be your internet-facing interface, and when asked to bridge it type 'yes'. Then you can configure the networking settings of your bridge device, br0
, as you would have configured your internet-facing interface.
Now continue with your installation to disk until you reach the 'reboot' prompt. There are a few more things to do before you can boot without errors:
# xen-hypervisor isn't installed by default with Xen so we must install it manually apk add xen-hypervisor apk add bridge
Now you can safely reboot after removing your install medium, making sure to pick the Alpine Linux v3.12, with Xen 4.13.1 and Linux lts
boot option in your GRUB menu, with 3.12 and 4.13.1 replaced with your Linux and Xen version numbers, respectively.
After this, enable the Alpine community repository and install the firmware to be used for Xen's virtual machines:
apk add seabios ovmf
Now you are ready to configure GRUB.
Existing installation
First you must enable the Alpine community repository, then install Xen and the seabios (BIOS) and ovmf (UEFI) firmwares for its virtual machines.
# apk add xen xen-hypervisor seabios ovmf
This will install Xen Hypervisor, xl cli command and all the required packages. The next step is to modify your GRUB configuration to properly boot Xen.
GRUB configuration
Once running a Xen kernel we will need to edit its command-line options and enable the setting of a default GRUB entry by inserting this at the bottom of /etc/default/grub
:
Contents of /etc/default/grub
You can replace 1024M with the amount of memory you want to allocate to your Dom0 operating system. After this you need to run the following:
grub-mkconfig -o /boot/grub/grub.cfg grub-set-default "$(grep ^menuentry | grep Xen | cut -d \' -f 2 | head -1)"
What this does is set your default entry in GRUB to the first entry containing 'Xen'. Run this every time you upgrade Alpine or Xen.
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