Fast Firecracker microVM manager
Project description
BandSox
Python library and CLI for managing Firecracker microVMs. Create, snapshot, and restore sandboxes from Docker images. Runs untrusted code or isolates workloads.
Features
- Millisecond boot times via Firecracker
- Create VMs from Docker images
- Pause, resume, and snapshot VMs for instant restore
- Web dashboard with login, API key management, and terminal sessions
- CLI for all operations, including auth management
- Python API for scripting and integration
- TypeScript SDK for Node.js
- Optional authentication: API keys for programmatic access, session cookies for the dashboard. Off by default.
Usage
Quick start
Create a VM and run Python code:
from bandsox.core import BandSox
bs = BandSox()
vm = bs.create_vm("python:3-alpine", enable_networking=False)
result = vm.exec_python_capture("print('Hello from VM!')")
print(result['stdout']) # Hello from VM!
vm.stop()
Python API
from bandsox.core import BandSox
bs = BandSox()
# Create a VM from a Docker image (needs python preinstalled)
vm = bs.create_vm("python:3-alpine", name="test-vm")
print(f"VM started: {vm.vm_id}")
# Run a command
exit_code = vm.exec_command("echo Hello World > /root/hello.txt")
# Run Python code directly inside the VM
result = vm.exec_python_capture("print('Hello World')")
print(result['stdout']) # Hello World
# Read a file
content = vm.get_file_contents("/root/hello.txt")
print(content) # Hello World
vm.stop()
Remote server usage
If the BandSox server is already running somewhere, point the Python client at it:
from bandsox.core import BandSox
# With authentication
bs = BandSox("http://localhost:8000", headers={"Authorization": "Bearer bsx_your_key_here"})
vm = bs.create_vm("python:3-alpine", enable_networking=False)
result = vm.exec_python_capture("print('Hello from the server')")
print(result["stdout"])
vm.stop()
Web dashboard
Start the server:
sudo python3 -m bandsox.cli serve --host 0.0.0.0 --port 8000
Visit http://localhost:8000 to access the dashboard. Authentication is off by default -- see the Authentication section to enable it.
Authentication
Auth is off by default. All endpoints are open until you explicitly enable it.
To turn it on:
sudo bandsox auth init --storage /var/lib/sandbox
This creates auth.json in the storage directory and prints an admin password and API key. Save both -- the API key is only shown once. The CLI will offer to save the key to ~/.bandsox/credentials for you.
Once enabled, BandSox uses two auth methods:
API keys for programmatic access (CLI, SDK, direct HTTP calls). Pass them as Authorization: Bearer <key> headers.
Session cookies for the browser dashboard. Log in with the admin password at /login. Sessions are signed tokens that survive server restarts.
To disable auth again, delete auth.json from the storage directory.
CLI auth commands
# Enable auth (generates password + API key)
sudo bandsox auth init --storage /var/lib/sandbox
# Set or reset the admin password
sudo bandsox auth set-password --storage /var/lib/sandbox
# Create a new API key
bandsox auth create-key my-key
# List and revoke keys
bandsox auth list-keys
bandsox auth revoke-key bsx_k_<id>
SDK auth
TypeScript:
const bs = new BandSox({
baseUrl: "http://localhost:8000",
headers: { Authorization: "Bearer bsx_your_key_here" },
});
Python:
bs = BandSox("http://localhost:8000", headers={"Authorization": "Bearer bsx_your_key_here"})
CLI
BandSox includes a CLI tool bandsox (or python -m bandsox.cli).
# Create a VM
sudo python3 -m bandsox.cli create ubuntu:latest --name my-vm
# Open a terminal
sudo python3 -m bandsox.cli terminal <vm_id>
# Start the server
sudo python3 -m bandsox.cli serve --host 0.0.0.0 --port 8000
Prerequisites
- Linux with KVM support (bare metal or nested virtualization)
- Firecracker installed at
/usr/bin/firecracker - Python 3.8+
sudoaccess (required for TAP device networking)- Vsock kernel module (
virtio-vsock) in the guest kernel for fast file transfers (optional, falls back to serial)
Installation
From PyPI
# Using pip
pip install bandsox
# Using uv
uv pip install bandsox
Then initialize the required artifacts:
bandsox init --rootfs-url ./bandsox-base.ext4
From source
-
Clone the repo:
git clone https://github.com/HACKE-RC/Bandsox.git cd bandsox
-
Install:
pip install -e .
-
Initialize artifacts (kernel, CNI plugins, optional base rootfs):
bandsox init --rootfs-url ./bandsox-base.ext4
This downloads:
vmlinux(Firecracker kernel)- CNI plugins into
cni/bin/ - (Optional) a base rootfs
.ext4intostorage/images/when--rootfs-urlis provided
Default URLs are provided for kernel and CNI. For the rootfs, build one locally (instructions below) and point
--rootfs-urlto a local path orfile://URL. Use--skip-*flags to omit specific downloads or--forceto re-download.
Architecture
BandSox has four main modules:
bandsox.core-- manages VMs, snapshots, and CID/port allocation.bandsox.vm-- wraps the Firecracker process; handles config, networking, vsock bridge, and guest interaction.bandsox.agent-- a small Python agent injected into the VM that runs commands and transfers files (vsock or serial).bandsox.server-- FastAPI backend for the web dashboard and REST API, with built-in authentication.bandsox.auth-- optional authentication. Whenauth.jsonexists, enforces API key and session auth. Stores hashed keys and a signing secret. Sessions are HMAC-signed tokens (no server-side state). Rate-limits login attempts.
Communication
Vsock (primary):
- VMs talk to the host via
AF_VSOCKsockets - Firecracker forwards vsock connections to Unix domain sockets
Serial (fallback):
- Used when vsock is unavailable (e.g., custom kernels without
virtio-vsock)
Storage layout
Default: /var/lib/bandsox (override with BANDSOX_STORAGE env var)
├── images/ # Rootfs ext4 images
├── snapshots/ # VM snapshots
├── sockets/ # Firecracker API sockets
├── metadata/ # VM metadata (including vsock_config)
├── auth.json # API key hashes, admin password hash, session signing secret
├── cid_allocator.json # CID allocation state
└── port_allocator.json # Port allocation state
Docs and API reference
- Full library, CLI, and HTTP endpoint reference:
docs/API.md - Vsock migration guide:
docs/VSOCK_MIGRATION.md - Vsock restoration fix:
VSOCK_RESTORATION_FIX.md - REST base path:
http://<host>:<port>/api(all endpoints require auth -- see API docs)
Building a local base rootfs
Build a minimal ext4 from a Docker image:
IMG=alpine:latest # pick a base image with python if needed
OUT=bandsox-base.ext4
SIZE_MB=512 # increase for more disk
TMP=$(mktemp -d)
docker pull "$IMG"
CID=$(docker create "$IMG")
docker export "$CID" -o "$TMP/rootfs.tar"
docker rm "$CID"
dd if=/dev/zero of="$OUT" bs=1M count=$SIZE_MB
mkfs.ext4 -F "$OUT"
mkdir -p "$TMP/mnt"
sudo mount -o loop "$OUT" "$TMP/mnt"
sudo tar -xf "$TMP/rootfs.tar" -C "$TMP/mnt"
cat <<'EOF' | sudo tee "$TMP/mnt/init" >/dev/null
#!/bin/sh
export PATH=/usr/local/bin:/usr/bin:/bin:/sbin
mount -t proc proc /proc
mount -t sysfs sysfs /sys
mkdir -p /dev/pts
mount -t devpts devpts /dev/pts
P=$(command -v python3 || command -v python)
[ -z "$P" ] && exec /usr/local/bin/agent.py
exec "$P" /usr/local/bin/agent.py
EOF
sudo chmod +x "$TMP/mnt/init"
sudo mkdir -p "$TMP/mnt/usr/local/bin"
sudo cp bandsox/agent.py "$TMP/mnt/usr/local/bin/agent.py"
sudo chmod 755 "$TMP/mnt/usr/local/bin/agent.py"
sudo umount "$TMP/mnt"
sudo e2fsck -fy "$OUT"
sudo resize2fs -M "$OUT" # optional: shrink to minimum
rm -rf "$TMP"
Use it with bandsox init --rootfs-url ./bandsox-base.ext4.
You can also skip the base rootfs entirely -- BandSox builds per-image rootfs on demand from Docker images when you call bandsox create <image>.
Storage and artifacts
- Large artifacts (ext4 rootfs images, snapshots,
vmlinux, CNI binaries) are not tracked in git.bandsox initdownloads them intostorage/andcni/bin/. - Default storage path is
/var/lib/sandbox; override withBANDSOX_STORAGEor--storage. - You can pre-seed a base rootfs via
--rootfs-url file://..., or let BandSox build per-image rootfs from Docker images on demand.
Verification and testing
The verification/ directory has smoke-test scripts:
verify_bandsox.py-- general smoke testverify_file_ops.py-- file upload/downloadverify_internet.py-- network connectivity inside the VM
To run one:
sudo python3 verification/verify_bandsox.py
License
Apache License 2.0
Note: This project wasn't supposed to be made public so it may have artifacts which make no sense. Please open issues so I can remove them.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file bandsox-3.3.tar.gz.
File metadata
- Download URL: bandsox-3.3.tar.gz
- Upload date:
- Size: 138.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2b0d4ab35df6184f1363f297b524c96738b64b2e6e376e9ec5646d18be0909a0
|
|
| MD5 |
75b58fc2504e005b3d520662fef55dd3
|
|
| BLAKE2b-256 |
6ceb30a02e9c30e8fccdc9361a42b189aece5e4a26022372c946e5fcc797d32b
|
File details
Details for the file bandsox-3.3-py3-none-any.whl.
File metadata
- Download URL: bandsox-3.3-py3-none-any.whl
- Upload date:
- Size: 157.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0955a52ecc9cd4a24d0306768815258f7da713e063c6329b272d9f26bc051d3a
|
|
| MD5 |
f694942f00ffb3873780df2970778a8d
|
|
| BLAKE2b-256 |
828747b7b5d72b89538b0339996638d5be1df10b4690ad156381d6a3c1392855
|