Skip to main content

A QEMU wrapper adding vagrant support and shared folders

Project description

Demo Gif

transient

Documentation Status

transient is a wrapper around QEMU that provides additional features like downloading and building disk images, shared folders, and SSH support.

Motivation

The primary motivation for the development of transient is to have a simple way to create short-lived virtual machines for testing and development, particularly kernel and hypervisor development. There are many other tools for creating virtual machines, such as vagrant or the many libvirt based solutions. However, these are almost always very stateful. It can be difficult to create virtual machines using these tools in CI environments, as the state may not always be appropriately synchronized. Also, these tools can make it more difficult to supply an existing kernel/initramfs when booting the virtual machine.

Almost all linux-based virtualization tools ultimately rely on qemu. transient makes this dependency transparent, allowing the user the entire flexibility of QEMU. This can be very helpful, for example, when attempting to setup complex virtual networking situations which may be difficult to express in the abstractions provided by other tools.

Installation

transient is available on PyPI, so the latest release can be installed with pip install transient. It is also available from GNU Guix, and can be installed with guix install python-transient. To install transient from source, clone this repository and run pip install -e '.[dev]' from the project root. As always, the usage of python virtual environments is recommended for a development setup. The development environment can also be built by running make dev from the project root.

transient has very few dependencies. On Ubuntu, these can be installed by running apt-get install ssh qemu-system-x86 python3-pip.

Documentation

Documentation for transient is available on Read the Docs.

Quick Start

transient is primarily a wrapper for QEMU. It supplies a small set of flags that are used to add additional features to the VM being started. As the name implies, it is almost completely stateless. This avoids problems that can sometimes occur with libvirt based tools becoming 'unsynchronized' with the real system state.

For example, in the following command, the flags before the -- are passed to transient. The remaining arguments are passed directly to QEMU. This example will cause transient to download and run a Centos7 VM (from the Vagrant Cloud) with 1GB of memory using a text console. This virtual machine will be automatically shut down on exit and its disk will be destroyed.

transient run centos/7:2004.01 -- -nographic -enable-kvm -m 1G

transient also supports a vagrant style SSH connection. This will start the virtual machine and connect standard input and output to an SSH connection with the machine, instead of the serial console. However, when this connection is closed, the machine will be automatically shut down (unlike vagrant). For example:

transient run centos/7:2004.01 --ssh-console -- -enable-kvm -m 1G

The --ssh-console flag depends on the image having the normal vagrant keypair trusted for the vagrant user.

Building Images

One side-effect of the development of transient was to create a Dockefile-like declarative file that can be used to build virtual machine disk images. For example, the file below would build a Centos 7 image based on the existing vagrant image centos/7:2004.01 but with nano installed and a hostname change:

FROM centos/7:2004.01
RUN yum install -y nano
RUN echo 'myhostname' > /etc/hostname

For additional information on building images, see the Building Images page of the docs.

License

This project is licensed under the terms of the MIT license. See the LICENSE file for details

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

transient-0.24.tar.gz (17.9 MB view details)

Uploaded Source

Built Distribution

transient-0.24-py3-none-any.whl (17.9 MB view details)

Uploaded Python 3

File details

Details for the file transient-0.24.tar.gz.

File metadata

  • Download URL: transient-0.24.tar.gz
  • Upload date:
  • Size: 17.9 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.7.1 requests/2.23.0 setuptools/57.4.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for transient-0.24.tar.gz
Algorithm Hash digest
SHA256 d33f1e2e29596d654eeaf99c12be54cd628fc70c452e917901c09771ef8f4e1f
MD5 65d5d3901948f8691e6bc72bd19bbfff
BLAKE2b-256 4a60aa68a8244fbf0b573365381eea983aceb0aa4be20ee6c2727ca74175b25f

See more details on using hashes here.

File details

Details for the file transient-0.24-py3-none-any.whl.

File metadata

  • Download URL: transient-0.24-py3-none-any.whl
  • Upload date:
  • Size: 17.9 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.7.1 requests/2.23.0 setuptools/57.4.0 requests-toolbelt/0.9.1 tqdm/4.62.2 CPython/3.9.7

File hashes

Hashes for transient-0.24-py3-none-any.whl
Algorithm Hash digest
SHA256 719be1c5a98bf9baa5d067d0d3de67f4294c3a70ebd0a8e545db2577e21425d6
MD5 5a196a0c3cf8636d36695bbe50ff8b4b
BLAKE2b-256 1eb155877e5568f7c2e6996eec5c134686d896bd3aec34b7e6d6ec53d8c38706

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page