add README with usage, architecture, and examples
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
f997b72f40
commit
e196160aac
1 changed files with 131 additions and 0 deletions
131
README.md
Normal file
131
README.md
Normal file
|
|
@ -0,0 +1,131 @@
|
||||||
|
# vmix
|
||||||
|
|
||||||
|
Composable QEMU VM image building and orchestration for NixOS.
|
||||||
|
|
||||||
|
## What it does
|
||||||
|
|
||||||
|
vmix provides:
|
||||||
|
- **Image building** — reproducible Linux (Debian) and Windows qcow2 images via Nix derivations
|
||||||
|
- **NixOS module** — declarative VM management with QEMU in network namespaces
|
||||||
|
- **CLI tool** — build, copy-to-disk, and run images from the command line
|
||||||
|
|
||||||
|
## Usage
|
||||||
|
|
||||||
|
### As a flake input
|
||||||
|
|
||||||
|
```nix
|
||||||
|
# flake.nix
|
||||||
|
inputs.vmix.url = "git+https://git.sagar.ch/dotfiles/vmix.nix.git";
|
||||||
|
|
||||||
|
# In your NixOS configuration (or globally via serverFunctions)
|
||||||
|
imports = [ inputs.vmix.nixosModules.default ];
|
||||||
|
|
||||||
|
# Use vmixLib via overlay
|
||||||
|
nixpkgs.overlays = [ inputs.vmix.overlays.default ];
|
||||||
|
# Then: pkgs.vmixLib.linux, pkgs.vmixLib.windows, pkgs.vmixLib.network
|
||||||
|
```
|
||||||
|
|
||||||
|
### As a CLI
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# Enter dev shell
|
||||||
|
nix develop
|
||||||
|
|
||||||
|
# Build an image
|
||||||
|
vmix build --image windows.images.win10.laptop \
|
||||||
|
--generalize username=User,password=secret,hostname=PC
|
||||||
|
|
||||||
|
# Write to local disk
|
||||||
|
vmix copy --image windows.images.win10.laptop \
|
||||||
|
--generalize username=User,password=secret \
|
||||||
|
--to-disk /dev/sda
|
||||||
|
|
||||||
|
# Write to remote disk (streamed via SSH + LZ4)
|
||||||
|
vmix copy --image windows.images.win10.laptop \
|
||||||
|
--generalize username=User,password=secret \
|
||||||
|
--to-remote-disk root@10.10.10.100:/dev/nvme0n1
|
||||||
|
|
||||||
|
# Boot a built image with QEMU
|
||||||
|
vmix run ./result --mem 8192 --smp 8 --ahci
|
||||||
|
```
|
||||||
|
|
||||||
|
## Flake outputs
|
||||||
|
|
||||||
|
| Output | Description |
|
||||||
|
|--------|-------------|
|
||||||
|
| `overlays.default` | Nix overlay exposing `pkgs.vmixLib` |
|
||||||
|
| `nixosModules.default` | NixOS module for declarative VM management |
|
||||||
|
| `lib.x86_64-linux` | Library functions (images + network utilities) |
|
||||||
|
| `packages.x86_64-linux.default` | vmix CLI tool |
|
||||||
|
| `apps.x86_64-linux.default` | Runnable vmix app |
|
||||||
|
|
||||||
|
## Repository structure
|
||||||
|
|
||||||
|
```
|
||||||
|
flake.nix # Flake entry point
|
||||||
|
module.nix # NixOS module export
|
||||||
|
overlay.nix # Nix overlay (vmixLib pinned to nixpkgs 25-11)
|
||||||
|
cli.nix # CLI tool (build, copy, run)
|
||||||
|
|
||||||
|
lib/
|
||||||
|
default.nix # Exports: images (linux + windows) + network
|
||||||
|
network.nix # IPv4/CIDR utilities
|
||||||
|
images/
|
||||||
|
linux/ # Debian image building + customization
|
||||||
|
windows/ # Windows image building + customization
|
||||||
|
helpers/ # makeImage, customizeImage, makeWinISO, etc.
|
||||||
|
templates/ # Registry tweaks, app installers, essentials
|
||||||
|
drivers/ # VirtIO, AMD GPU drivers
|
||||||
|
win10/ # Windows 10 LTSC images
|
||||||
|
win11/ # Windows 11 images
|
||||||
|
|
||||||
|
nixos/
|
||||||
|
default.nix # NixOS module entry point
|
||||||
|
networks/ # Network namespace management (LAN, WAN, macvtap)
|
||||||
|
vms/ # VM lifecycle management (QEMU, tap devices, DHCP)
|
||||||
|
```
|
||||||
|
|
||||||
|
## Image building
|
||||||
|
|
||||||
|
### Windows pipeline
|
||||||
|
|
||||||
|
1. `makeImage` — unattended install from upstream ISO via QEMU
|
||||||
|
2. `customizeImageFold` — apply modular templates (registry, apps, drivers)
|
||||||
|
3. `generalize` — sysprep + OOBE for deployment to real hardware
|
||||||
|
|
||||||
|
### Linux pipeline
|
||||||
|
|
||||||
|
1. Fetch upstream Debian cloud image
|
||||||
|
2. `customizeImageFold` — apply templates via `virt-customize`
|
||||||
|
|
||||||
|
### Key patterns
|
||||||
|
|
||||||
|
- **`customizeImageFold`** — `builtins.foldl'` over templates for composable layered images
|
||||||
|
- **`_vmixOsType`** — all images carry `"linux"` or `"windows"` metadata for auto-detection
|
||||||
|
- **Offline registry** — Windows templates use `ControlSet001` for offline `virt-win-reg --merge`
|
||||||
|
|
||||||
|
## NixOS module
|
||||||
|
|
||||||
|
Declare VMs and networks:
|
||||||
|
|
||||||
|
```nix
|
||||||
|
vmix.namespaces."lab" = {
|
||||||
|
networks.lan1 = {
|
||||||
|
subnet = "10.99.1.0/24";
|
||||||
|
dhcp.enable = true;
|
||||||
|
};
|
||||||
|
vms.myvm = {
|
||||||
|
image = pkgs.vmixLib.linux.images.debian.v12.upstream;
|
||||||
|
memory = 2048;
|
||||||
|
cores = 2;
|
||||||
|
interfaces.lan1 = { ip = "10.99.1.10"; };
|
||||||
|
autostart = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
```
|
||||||
|
|
||||||
|
Features:
|
||||||
|
- Network namespaces with WAN (veth), LAN (bridge + dnsmasq), macvtap
|
||||||
|
- ACPI graceful shutdown via QMP socket
|
||||||
|
- 9p shares with auto-created mount targets
|
||||||
|
- Conditional macvtap service (only created when macvtaps are configured)
|
||||||
Loading…
Add table
Add a link
Reference in a new issue