No edit summary |
|||
Line 24: | Line 24: | ||
* Dom0 backend drivers, [https://bugzilla.redhat.com/show_bug.cgi?id=692203 Bugzilla #692203] | * Dom0 backend drivers, [https://bugzilla.redhat.com/show_bug.cgi?id=692203 Bugzilla #692203] | ||
* power management, [https://bugzilla.redhat.com/show_bug.cgi?id=692179 Bugzilla #692179] | * power management, [https://bugzilla.redhat.com/show_bug.cgi?id=692179 Bugzilla #692179] | ||
* grubby support for syntax required by Xen, [https://bugzilla.redhat.com/show_bug.cgi?id=668063 Bugzilla #668063] | * grubby support for syntax required by Xen, [https://bugzilla.redhat.com/show_bug.cgi?id=668063 Bugzilla #668063] | ||
* new-kernel-pkg and HYPERVISOR option in /etc/sysconfig/kernel, [https://bugzilla.redhat.com/show_bug.cgi?id=658387 Bugzilla #658387] | * new-kernel-pkg and HYPERVISOR option in /etc/sysconfig/kernel, [https://bugzilla.redhat.com/show_bug.cgi?id=658387 Bugzilla #658387] | ||
* bridging in NetworkManager, [https://bugzilla.redhat.com/show_bug.cgi?id=199246 Bugzilla #199246] | * bridging in NetworkManager, [https://bugzilla.redhat.com/show_bug.cgi?id=199246 Bugzilla #199246] | ||
== Detailed Description == | == Detailed Description == |
Revision as of 04:17, 2 June 2011
Xen Pvops Dom0
Summary
pvops-based kernel
to serve as Dom0 for a Xen-based system. Currently Fedora releases greater than 8 contain the Xen hypervisor and tools, but not a Xen Dom0-capable kernel.
Owner
- Name: W. Michael Petullo
- Email: mike@flyn.org
- People Involved: Michael Young, Eduardo Habkost, Mark McLoughlin, Stephen Tweedie, Chris Wright, Juan Quintela, Markus Armbruster, Glauber Costa, Daniel Berrange et al.
Current status
- Targeted release: Fedora 16
- Last updated: 2010-06-01
- Percentage of completion: 50%
In order to implement this feature, it is necessary to get full Xen Dom0 support upstream and in Fedora. The core Dom0 support has been accepted upstream and was released in Linux 2.6.37. Linux 2.6.39 brought support for the Xen network backend driver. It is expected that Linux 3.0 will contain the block backend driver.
In order to support development until Xen is fully integrated into the upstream kernel, Michael Young has been building third-party Dom0 kernels. He creates a diff between upstream and the xen/stable-2.6.32.x branch and uses it to patch the Fedora 12 kernel package. The reason that he based his work on the Fedora 12 kernel is that newer Fedora versions ship newer kernels, while Xen had continued to target 2.6.32. As mentioned above, Xen now targets newer kernels, but all of the backend drivers are not yet ported to them.
Open bugs:
- Dom0 backend drivers, Bugzilla #692203
- power management, Bugzilla #692179
- grubby support for syntax required by Xen, Bugzilla #668063
- new-kernel-pkg and HYPERVISOR option in /etc/sysconfig/kernel, Bugzilla #658387
- bridging in NetworkManager, Bugzilla #199246
Detailed Description
Xen is a hypervisor-based type-1 virtualization solution. The Xen hypervisor requires a standard operating system that runs in a privileged domain, Dom0. The Dom0 operating system provides driver and guest management support to Xen and other guest operating systems running in the DomU domain. Fedora 8 provided a kernel that could serve as a Dom0 guest. However, newer Fedora releases dropped support for Dom0 (although they can run in DomU). The Xen project is presently pushing the features required for a Dom0 Linux kernel upstream. Once these features are available in the mainline kernel, it follows that Fedora could support Xen Dom0.
Benefit to Fedora
Fedora will benefit from a Xen Dom0-capable kernel. Xen has proven to be a competitive virtualization solution in real-world installations. Xen is different enough from KVM that the two technologies could complement each other within the Fedora Project. There are ongoing benchmarks that intend to define the relative performance of the two technologies.
Scope
- Implement Dom0 support in upstream kernel (Complete)
- Implement Dom0 backend drivers support in upstream kernel; fix remaining issues (Xen developers)
- Modify 'grubby' to support GRUB syntax required by Xen
- Make 'new-kernel-pkg' aware of Xen using the HYPERVISOR option in /etc/sysconfig/kernel
- Ensure Fedora's virtualization tools support Xen
- Possibly implement support for bridging in NetworkManager
- Possibly implement support in Anaconda
How To Test
- Install a Fedora Dom0 kernel and
xen
- Confirm grub.conf does not boot the new kernel using Xen
- Reboot
- Confirm the Dom0 kernel can boot on bare metal (no Xen)
- Turn on Xen Userspace by running 'chkconfig xend on'
- Turn on Xen Hypervisor by setting 'HYPERVISOR=/boot/xen-X.Y.gz' in /etc/sysconfig/kernel
- Remove and reinstall the Dom0 kernel
- Confirm grub.conf boots the new kernel using Xen
- Reboot
- Observe presence of Xen via /sys/hypervisor/
- Run 'xm list' and observe Domain-0
- Use 'virt-install' to deploy a Fedora paravirtualized guest
- Use 'virt-install' to deploy a Fedora fully virtualized guest
- Use 'virsh' to save & restore guests
- Balloon down memory of a guest with 'virsh'
User Experience
- Stock Fedora kernel supports both Xen dom0 and bare metal
- All features and hardware supported on bare metal also work on Xen Dom0
- Can enable and disable the use of the Xen hypervisor via an /etc/sysconfig/kernel setting
- Can manage Xen guests using Fedora virtualization tools
Dependencies
kernel
grubby
- Fedora virtualization tools
- (possibly)
anaconda
- (possibly)
NetworkManager
Contingency Plan
There is presently some uncertainty as to when the backend driver support that the Dom0 guest provides DomU guests will be upstream. This may make the upstream kernel that is chosen by Fedora 16 or it may not. Regardless, we will have to touch a lot of subsystems, so it makes sense to start early.
Until all of the requisite Xen components are upstream, we can continue to develop this feature using third party kernels. These third party kernels will be configured to be as close as possible to the forthcoming upstream kernel. In addition, Linux 2.6.39 does contain many of the backend drivers. It may be used with configurations that do not require the block backend driver.
If all of the Xen backend drivers don't make Fedora 16, then little is lost. We can continue to test the Dom0 kernel (with a subset of its eventual features) and work on the supporting infrastructure. It would be useful for our effort to have a working Dom0, grubby, etc in Fedora 16 even if other features (most notably the block backend driver) do not make it. In the worst case, we may delay the announcement of the Dom0 feature to Fedora 17, but can include all progress completed in Fedora 16.
Documentation
See also:
- Xen, http://www.xen.org/
- The Xen mailing lists, hosted at xen.org
- The fedora-xen mailing list, hosted by Fedora
- "Dom0 xen support in Fedora 15?" on fedora-xen mailing list, http://lists.fedoraproject.org/pipermail/xen/2010-November/005205.html
- Michael Young's third-party Dom0 kernels, http://fedorapeople.org/~myoung/dom0/
- Stefano Stabellini's announcement that Xen Dom0 support has been included in Linux 2.6.27, http://blog.xen.org/index.php/2011/01/14/linux-2-6-37-first-upstream-linux-kernel-to-work-as-dom0/
In order to configure a system to boot Michael Young's kernel in Dom0 on a present Fedora system:
1. yum install xen.
2. Install a Dom0 kernel package.
3. Use grubby to create a grub.conf entry in a manner such as the following:
KERNEL_VERSION=2.6.32.23-170.1.xendom0.fc12.x86_64 ROOT_UUID=`blkid /dev/sda3 -s UUID | awk -F = '{ print $2 }' | tr -d '"'` grubby \ --add-multiboot=/boot/xen.gz \ --add-kernel=/boot/vmlinuz-${KERNEL_VERSION} \ --args="ro root=UUID=${ROOT_UUID} [...]" \ --initrd=/boot/initramfs-${KERNEL_VERSION}.img \ --title="Fedora (${KERNEL_VERSION})"
4. Configure a bridge device by setting /etc/sysconfig/network-scripts/ifcfg-virbr0:
DEVICE=virbr0 TYPE=Bridge ONBOOT=yes USERCTL=no BOOTPROTO=dhcp NM_CONTROLLED=no
5. Configure eth0 to be a member of the bridge:
DEVICE=eth0 HWADDR=[XX:XX:XX:XX:XX:XX] TYPE=Ethernet ONBOOT=yes USERCTL=no BOOTPROTO=none BRIDGE=virbr0 NM_CONTROLLED=no
6. Reboot and select your Xen kernel in the GRUB boot menu
Release Notes
The Fedora Linux kernel may now provide the basis for a Xen-based virtualization solution. Xen is a hypervisor-based type-1 virtualization platform. The kernel now has the ability to boot in Xen's Dom0, a privileged domain that allows Fedora to provide driver and guest management support to Xen and other non-privileged, guest operating systems.