Xen的基本概念

来源:互联网 发布:mysql unicode排序语句 编辑:程序博客网 时间:2024/05/16 10:15

Xen是什么?

Xen is a free source virtual machine monitor for IA-32, x86-64, IA-64 and PowerPC architectures. It is software that runs on a host operating system and allows one to run several guest operating systems on top of the host on the same computer hardware at the same time. Modified versions of Linux and NetBSD can be used as hosts. Several modified Unix-like operating systems may be employed as guest systems; on certain hardware, as of Xen version 3.0, unmodified versions of Microsoft Windows and other proprietary operating systems can also be used as guests.

Xen originated as a research project at the University of Cambridge, led by Ian Pratt, senior lecturer at Cambridge and founder of XenSource, Inc. This company now supports the development of the open source project and also sells enterprise versions of the software. The first public release of Xen was made available in 2003.

Virtual machine monitors (also known as hypervisors) are often used by IBM, HP, and others on mainframes and large servers. They are also increasingly being used by Internet hosting service companies to provide virtual dedicated servers. The primary benefits of server virtualization are consolidation, increased utilization, an ability to rapidly provision and start a virtual machine, and increased ability to dynamically respond to faults by re-booting a virtual machine or moving a virtual machine to different hardware. Another benefit is the ability to securely separate virtual operating systems, and the ability to support legacy software as well as new OS instances on the same computer. Xen's support for virtual machine live migration from one host to another allows workload balancing and the avoidance of downtime.

Xen may also be used on personal computers that run Linux but also have Windows installed. Traditionally, such systems are used in a dual boot setup, but with Xen it is possible to start Windows "in a window" from within Linux, effectively running applications from both systems at the same time.

Virtualization also has benefits when working on operating system development: running the new system as a guest avoids the need to reboot the computer whenever a bug is encountered. Such a "sandboxed" guest system is also useful in computer security research, in order to study the effects of some virus or worm without the possibility of compromising the host system. Finally, hardware appliance vendors may decide to ship their appliance running several guest systems, so as to be able to execute various pieces of software that require different operating systems.

Xen can be delivered to market in two ways: as a virtualization platform, such as XenSource, Inc.'s XenEnterprise product, or embedded within the host operating system. An example of the latter configuration is the inclusion of Xen in Novell's SUSE 10 Linux distribution, Red Hat's RHEL 5, Sun Microsystems' Solaris 10, or Debian's Etch release.

XenSource is also developing a compatibility layer for Microsoft's Longhorn hypervisor, so that systems that have been modified to run as Xen guests will be able to function on the Longhorn hypervisor.

Dom0Domu

An operating system that runs Xen as host is also known as domain number 0 (dom0), while a system that runs as a Xen guest is known as the unprivileged domain (domU).

ParavirtualizationFully virtualization

Xen uses a form of virtualization known as paravirtualization, meaning that the guest operating system must be modified to use a special hypercall ABI instead of certain architectural features. Through paravirtualization, Xen can achieve high performance even on its host architecture (x86) which is notoriously uncooperative with traditional virtualization techniques. The Xen host kernel code runs in Ring 0, while the Xen domains run in Ring 1.

Intel has contributed modifications to Xen to support their VT-x (formerly Vanderpool) architecture extensions[2]. Similarly AMD has contributed support for their AMD-V extensions. These technologies, while differing quite substantially in their implementation and instruction sets, are managed by a common abstraction layer in Xen and enable unmodified guest operating systems to run within Xen virtual machines, starting with Xen 3.0.

In layman's terms, this has been a significant development because it allows proprietary operating systems (such as Microsoft Windows) to be virtualized since the guest system's kernel does not require modification when the host runs on VT-x or AMD-V hardware.

Hardware assisted virtualization offers new instructions to support direct calls by a paravirtualized guest/driver into the hypervisor, typically used for I/O or other so-called hypercalls. It also provides additional execution modes: "root mode" and "non-root mode". Both of these modes have Rings 0-3; the Xen host operates in root mode and has access to the real hardware, while the unmodified guest operates in Rings 0-3 of non-root mode and its "hardware" accesses are under complete control of the hypervisor.

As of Xen 3.0.2, the list of supported unmodified guests is limited to certain versions of Windows (incl. XP) and Linux.

Xen虚拟机的暂停和迁移

Xen virtual machines can be "live migrated" between physical hosts across a LAN without a noticeable loss of availability. During this procedure, the memory of the virtual machine is iteratively copied to the destination without stopping its execution. A very brief stoppage of around 60–300 ms is required to perform final synchronisation before the virtual machine begins executing at its final destination, providing an illusion of seamless migration. Similar technology is used to suspend running virtual machines to disk and switch to another virtual machine, and resume the first virtual machine at a later date.

Unix系统上的Xen

Xen mainly runs with modified Linux or NetBSD as a host system. Most Linux distributions now include Xen packages. Xen under Linux currently runs on x86, with Pentium II or newer processors, x86-64 based systems, as well as on IA-64 and PowerPC. Work is under way on a port to the SPARC architecture. Xen supports up to 64-way SMP multi-processing machines.

XenSource offers a live ISO CD running Debian GNU/Linux as well as other free Linux distributions that enables users to try Xen on their system without installing it to the hard disk. The first commercial implementation of Xen in this form is Novell's SUSE Linux Enterprise Server 10 release, which is broadly supported. Red Hat Enterprise Linux 5 also offers support for Xen.

Fedora Core has included Xen packages since its FC4 release. A quick-start document is available.openSUSE includes Xen 3.0 support. Graphical VM management is offered by YaST.

Ubuntu includes Xen 3.0.3 packages in its 6.10 and 7.04 release (codenamed Edgy Eft and Feisty Fawn) in package named xenman. Debian includes Xen 3.0.3 packages in its 4.0 release (codenamed Etch). Packages for Debian 3.1 (Sarge) can be found on http://www.backports.org. Host support for Xen 2 is included in NetBSD 3.x. Host support for Xen 3.0 is available in current and the 4.0 pre-release branches. Support for OpenBSD self-hosting is near complete, requiring the correction of a lock-up bug before its release. Support for using FreeBSD as a Xen host is being worked on. A Gentoo package exists for Xen in Portage.

支持Paravirtualization的类Unix系统

Guest systems can run fully virtualized (requires special hardware) or paravirtualized (requires guest OS code modification). The following systems have been patched so that they can operate as a paravirtualized Xen guest:

  • Oz Linux released Version 0.0.1-4-1(Xen Virtual Appliance) utilizing Conary.
  • Minix
  • Plan 9 from Bell Labs
  • NetBSD (NetBSD 2.0 has support for Xen 1.2, NetBSD 3.0 has support for Xen 2.0, and NetBSD 3.1 supports Xen 3.0)
  • OpenBSD, announced here
  • FreeBSD (a patch against the CURRENT branch exists)
  • OpenSolaris (a BFU release exists; the source code and BFU archives can be downloaded from The Xen Community On OpenSolaris)
  • NetWare (at Brainshare 2005, Novell showed a port that is able to run as a Xen guest)
  • GNU/Hurd/Mach (gnumach-1-branch-Xen-branch)
  • OZONE (has support for Xen v1.2)

Xen上运行Windows OS

It is currently possible to run Microsoft Windows as a guest operating system unmodified, using hardware virtualization provided by Intel's Vanderpool technology or AMD's Pacifica. This is supported beginning with Xen 3.0.

During the development of Xen 1.x, Microsoft Research, along with the University of Cambridge Operating System group, developed a port of Windows XP to Xen. This was possible due to Microsoft's Academic Licensing Program. The terms of this license do not allow this port to be published, although the experience is documented in the original Xen SOSP paper.

Xen工具

A number of third-party tools (known as Xen Management Consoles) have been developed to facilitate the common tasks of administrating a Xen host, such as configuring, starting, monitoring and stopping of Xen guests. Examples include the Python-based Enomalism dashboard (LGPL), Xen Tools, the Perl-based MLN, the web-based HyperVM, and the GUI applications ConVirt (formerly XenMan) and RedHat's Virtual Machine Manager, virt-manager. 

原创粉丝点击