Skip to content
/ vml Public

Tool for easily and transparently work with qemu virtual machines

License

Notifications You must be signed in to change notification settings

Obirvalger/vml

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

vml

VML is a tool for easily and transparently work with qemu virtual machines. Virtual machines present as directories with vml.toml files in it. VML is able to initialize images with cloud-init. Virtual machines with ALT, Centos, Debian, Fedora, openSUSE and Ubuntu could be created with just one command.

Build

All needed dependencies saved into vendor directory, so it can be built in the offline mode.

cargo build --release --offline

Then copy created executable to appropriate path, e.g. ~/bin/vml, if ~/bin is in your PATH.

cp target/release/vml ~/bin/vml

The following programs (packages) should be installed:

  • kvm (qemu-kvm)
  • rsync
  • socat
  • cloud-localds (cloud-utils)

User running vml should be able to use kvm (.e.g be in vmusers group).

Build with docker

To build vml with docker run the following commands:

  1. Build binary in image;
docker build -t vml-builder .
  1. Run container with binary;
docker run --name vml-builder vml-builder
  1. Copy binary from container to host directory (it should be in PATH);
docker cp vml-builder:/usr/src/vml/target/release/vml ~/bin/
  1. Remove building container and image.
docker rm -f vml-builder
docker rmi -f vml-builder

Run

All needed files are copied with any command. For example list available to pull images.

vml image available

Or get completion for your shell (zsh in example).

vml completion zsh

Then edit config with your preferences.

$EDITOR ~/.config/vml/config.toml

Run vm named test, using alt-sisyphus image.

vml run -i alt-sisyphus --wait-ssh -n test

VM test is described via directory test in <vms-dir> (vms-dir from config) and within files: disk.qcow2 is a disk image, vml.toml is a current vm config file. By default vml.toml is empty, but it is needed to mark the directory as vml vm. Some fields of the vml.toml have names as default section fields of the main config file ~/.config/vml/config.toml.

Finally ssh to the test vm.

vml ssh -n test

About

Tool for easily and transparently work with qemu virtual machines

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published