clan-munix/README.md

57 lines
1.5 KiB
Markdown
Raw Normal View History

2025-09-25 22:29:24 -03:00
# munix
WIP: A microVM runner for NixOS systems with desktop integration, powered by muvm/libkrun.
2025-11-03 17:56:25 +01:00
## Quick Start
**1. Build a test VM:**
```bash
nix build '.#nixosConfigurations.testvm-x86_64.config.system.build.toplevel' -o testvm
```
**2. Run the VM:**
```bash
nix run '.#munix' -- testvm
```
This will start an interactive bash session inside the microVM.
**Run a specific command:**
```bash
nix run '.#munix' -- testvm fastfetch
```
## munix Options
- `--uid UID`, `-u UID` - Set microVM UID (default: 1337)
- `--gid GID`, `-g GID` - Set microVM GID (default: 1337)
- `--no-gpu` - Disable GPU acceleration
- `--no-wayland` - Disable Wayland support
- `--no-pipewire` - Disable PipeWire audio
- `--x11` - Enable X11 support
- `--bind SRC DST` - Bind mount SRC to DST in the VM
- `--ro-bind SRC DST` - Read-only bind mount
- `--expose PATH` - Expose PATH in the VM at the same location
- `--ro-expose PATH` - Expose PATH read-only
Example with options:
```bash
nix run '.#munix' -- --no-gpu --ro-expose /home/user/data testvm htop
```
2025-09-25 22:29:24 -03:00
## Development
Working on muvm & munix locally (not built into the nix store):
2025-11-03 17:56:25 +01:00
```bash
2025-09-25 22:29:24 -03:00
cd muvm && cargo build --locked --release
2025-11-03 17:56:25 +01:00
PATH=$PWD/muvm/target/release:$PATH ./munix testvm
2025-09-25 22:29:24 -03:00
```
2025-11-03 17:56:25 +01:00
## Requirements
- Linux system with KVM support (`/dev/kvm`)
- For GPU acceleration: Kernel 6.13+ with compatible drivers (amdgpu, msm)
- For Wayland: `XDG_RUNTIME_DIR` and `WAYLAND_DISPLAY` set
- For audio: PipeWire running with `PIPEWIRE_RUNTIME_DIR` or `XDG_RUNTIME_DIR`