Giter Club home page Giter Club logo

xen-tools

Travis CI Build Status

About

xen-tools contains a collection of Perl scripts for working with Xen guest images under Linux.

Using this software, you can easily create new Xen guests configured to be accessible over the network via OpenSSH.

xen-tools currently has scripts to install most releases of Debian (starting with 3.1 "Sarge") and Ubuntu (starting with 6.06 LTS "Dapper") and some RPM-based distributions. On the Dom0 side all current Xen supporting distributions should work.

However, currently only Debian and Ubuntu releases are tested and known to work reliably, i.e.:

Debian

  • Sarge 3.1 (i386 and DomU only) ¹
  • Etch 4.0 (Dom0 no more tested) ¹
  • Lenny 5.0 (Dom0 no more tested) ¹
  • Squeeze 6.0 (Dom0 no more tested) ¹
  • Wheezy 7 (Dom0 no more tested) ¹
  • Jessie 8
  • Stretch 9
  • Buster 10
  • Bullseye 11
  • Bookworm 12 (under development)
  • Trixie 13 (knows about this future release name)
  • Forky 14 (knows about this future release name)
  • Sid (always under development; works at least at the moment of writing :-)

Ubuntu

(only DomUs tested)

  • Dapper Drake 6.06 (LTS) ¹ ²
  • Edgy Eft 6.10 ¹ ²
  • Feisty Fawn 7.04 ¹
  • Gutsy Gibbon 7.10 ¹
  • Hardy Heron 8.04 (LTS, see Installing Ubuntu 8.04 as DomU) ¹
  • Interpid Ibex 8.10 ¹
  • Jaunty Jackaplope 9.04 ¹
  • Karmic Koala 9.10 ¹
  • Lucid Lynx 10.04 (LTS) ¹
  • Maverick Meerkat 10.10 ¹
  • Natty Narwhal 11.04 ¹
  • Oneiric Ocelot 11.10 ¹
  • Precise Pangolin 12.04 (LTS) ¹
  • Quantal Quetzal 12.10
  • Raring Ringtail 13.04
  • Saucy Salamander 13.10
  • Trusty Tahr 14.04 (LTS)
  • Utopic Unicorn 14.10
  • Vivid Vervet 15.04
  • Wily Werewolf 15.10
  • Xenial Xerus 16.04 (LTS)
  • Yakkety Yak 16.10
  • Zesty Zapus 17.04
  • Artful Aardvark 17.10
  • Bionic Beaver 18.04 (LTS)
  • Cosmic Cuttlefish 18.10
  • Disco Dingo 19.04
  • Eoan Ermine 19.10
  • Focal Fossa 20.04 (LTS)
  • Groovy Gorilla 20.10
  • Hirsute Hippo 21.04 (under development)

Footnotes

¹

Installation with xen-create-image and updating with xen-update-image might fail with newer kernels/distributions running on the Dom0 unless they have been booted with vsyscall=emulate on the kernel commandline.

²

At least between debootstrap version 1.0.37 and 1.0.93 (including) these distributions needs editing of /usr/share/debootstrap/scripts/edgy, see #659360.

CentOS

(only DomUs tested, pygrub support incomplete)

  • CentOS 5
  • CentOS 6

Packages

xen-tools are available prepackaged in Debian (and derivates) and as source tar-ball for local installation. Installing from source should work flawlessly on most Linux systems that meet the installation requirements.

Requirements

To use these tools you'll need the following software:

You can try to install RPM-based distributions such as CentOS, or Fedora Core, but you will need a correctly installed and configured rinse package. This is currently not fully supported.

If you wish to create new Xen instances which may be controlled by users via a login shell you can have a look at the (currently unmaintained) xen-shell project.

Caveats

For security reasons (avoid risk to circumvent ASLR), recent kernels have disabled the vsyscall mapping. Unfortunately older distributions don't run and hence can't be bootstrapped without it.

To enable trapping and enabling emulate calls into the fixed vsyscall address mapping and hence to run and bootstrap older Linux distributions in a chroot (as xen-tools does), you need to add vsyscall=emulate to the kernel commandline, e.g. by adding it to GRUB_CMDLINE_LINUX_DEFAULT in /etc/default/grub, then running update-grub afterwards and finally reboot.

Installation

As root or with sudo, execute make install.

See debian/README.source how to build the Debian package from a checked out copy of the git repository (i.e. without a source tar ball).

The Scripts

Here is a brief description of each included script, for more thorough documentation please consult the appropriate man page.

xen-create-image

This script is designed to create new images which may be used with the Xen hypervisor.

This script performs the initial setup, then delegates the real work to a collection of helper scripts:

  • xt-install-image: Installs a distribution into a directory.

  • xt-customize-image: Run a collection of hook scripts to configure the freshly installed system.

  • xt-create-xen-config: Create a configuration file in /etc/xen such that Xen can boot the newly created machine.

  • xt-guess-suite-and-mirror: In case of a Debian or Ubuntu Dom0, this script tries to guess the most suitable suite and mirror for DomUs based on the Dom0's /etc/apt/sources.list.

xen-create-nfs

This script is similar in spirit to xen-create-image, but much less complex. It allows the creation of Xen guests which are diskless, mounting their root filesystem over a remote NFS-share.

There are not many options to tweak, but still a useful addition to the suite.

xen-delete-image

This script will allow you to completely remove Xen instances which have previously been created by xen-create-image, this includes removing the storage block devices from the system, and deleting the Xen configuration file.

xen-list-images

List all the created images beneath a given root directory along with a brief overview of their setup details.

xen-update-image

This script runs "apt-get update; apt-get upgrade" for a given Xen image.

NOTES

  • The image should not be running or corruption will occur!
  • The script should only be used for Xen instances of Debian or a Debian-derived distribution.

Version Numbering Scheme

Since release 4.4, the version numbering scheme of xen-tools tries to comply with the Semantic Versioning specification, with the only exception that in releases before 4.10 trailing zeroes were omitted.

Between the releases 3.9 and 4.4, the version numbering scheme followed roughly the same ideas, but less strict.

Test Suite Coverage

Coverage Status

Despite parts of the test suite are quite old, it only tests a small fraction of what xen-tools can do. Some of the scripts currently could only be tested on an actual Xen Dom0. Hence the code coverage of xen-tools' test suite is quite bad.

Bugs

Reporting Bugs

If you're using the current packages included as part of the Debian GNU/Linux distribution or a derivative, please first report any bugs using the distribution's way to report bugs.

In case of Debian this would be using e.g. reportbug xen-tools.

If you're using the xen-tools built from source tar ball, please report bugs via GitHub's issue tracker, or, if you don't want to create a GitHub account or are not sure if it's really a bug, feel free to just write an e-mail to the xen-tools dicsussion mailing list.

If you're capable of fixing it yourself a patch is appreciated, and a test case would be a useful bonus.

Known/Open Issues

You can check the following ressources for known or open issues:

— The Xen-Tools Developer Team

xen-tools's Projects

xen-tools icon xen-tools

xen-tools is a collection of simple perl scripts which allow you to easily create new Xen guest domains upon your Xen host server.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.