A QEMU wrapper adding vagrant support and shared folders
Project description
transient
transient
is a thin 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.
Additionally, 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
. 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 \
-image 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 \
-ssh-console \
-image centos/7:2004.01 \
-- \
-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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file transient-0.11.tar.gz
.
File metadata
- Download URL: transient-0.11.tar.gz
- Upload date:
- Size: 17.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f4f4d1598e04405b6416d93bbb75e8ac57775a47253fc48cc2a40c2a24e29edd |
|
MD5 | df743c80dabdd1f0b1550134ec3b315a |
|
BLAKE2b-256 | d83180f212a9db7fdda2cb59f54009c37c7f8253ab56331d9e19286d0f8c3e06 |
File details
Details for the file transient-0.11-py3-none-any.whl
.
File metadata
- Download URL: transient-0.11-py3-none-any.whl
- Upload date:
- Size: 17.3 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f593e450696924b7f955783bcf1cb65e403b2d26f43b7a341a905bacb707a32c |
|
MD5 | b9ac8f340675d23f2f4d667a2b0e2763 |
|
BLAKE2b-256 | 7d3d89fb53153f9d3403b78e1277c8ce8d2c29e253cd0367420d9abfea954b1d |