/spinup

Spin up Linux VMs with QEMU

Primary LanguageGoGNU General Public License v3.0GPL-3.0

spinup

Spin up Linux VMs with QEMU.

Requirements

  • Linux, macOS or Windows (needs testing) host OS.
  • QEMU installed and available in the image, you can install it with homebrew or your package manager of choice. spinup uses qemu-img binary, qemu-system-aarch64 binary on ARM64 and qemu-system-x86_64 binary on AMD64.

Getting started

Install spinup

The only way for now is to have a working Go environment and install spinup by running this command:

go install github.com/Igr1s-red/spinup@latest

Create your first vitual machine

Create a Debian 12 (Bookworm) virtual machine with 4 CPUs, 4096 mebibytes of ram and 20 GB of disk by running this command:

spinup run debian12 -i debian:bookworm -c 4 -m 4096 -d 20

Run a command in the virtual machine

Run uname -a inside the virtual machine by running this command:

spinup exec debian12 -- uname -a

Connect to the virtual machine via SSH

You can get SSH parameters by running this command:

spinup ssh debian12

On Unix systems you can quickly connect via SSH by running this command:

$(spinup ssh debian12 --command)

Commands

Create a virtual machines (spinup run)

With spinup run you can create and start a new virtual machine.

spinup will automatically create a pair of SSH keys and configure the chosen system via cloud-init. If not specified, a forward to guest port 22 will be created using a free port. This will be used to access the virtual machine via SSH.

Example:

spinup run debian12 -i debian:bookworm -c 4 -m 4096 -d 20

Available options:

  • -c, --cpu number of cpu(s) (example: -c 4)
  • -d, --disk-size disk size in gigabytes (GB) (example: -d 20)
  • -i, --image image to use (example: -i debian:bookworm)
  • -m, --memory ram in mebibytes (MiB) (example: -m 4096)
  • -p, --port-forward forward host port to the virtual machine (example: -p 8080-80, -p [host]-[guest])

Remove a virtual machine (spinup remove|rm)

With spinup remove or spinup rm you can remove a virtual machine.

Example:

spinup remove debian12

Start a virtual machine (spinup start)

With spinup start you can start a virtual machine.

Example:

spinup start debian12

Stop a virtual machine (spinup stop)

With spinup stop you can stop a virtual machine.

Example:

spinup stop debian12

Contributing

Requirements

  • Go installed and available in the system.
  • Task installed and available in the system.