TheDocumentation Index
Fetch the complete documentation index at: https://docs.mirage.strukto.ai/llms.txt
Use this file to discover all available pages before exploring further.
mirage CLI is a thin httpx wrapper over the Mirage daemon. It
auto-spawns the daemon on first workspace create, and the daemon
auto-exits 30 seconds after the last workspace is deleted. Most users
never type a daemon command directly.
Output is structured JSON to stdout for every verb — pipe to jq,
save to file, or read it directly.
Install
Define a workspace in YAML
A workspace is a set of prefixed mounts plus some workspace-level settings. Save this asworkspace.yaml:
${VAR} placeholders are interpolated from your shell environment at
mirage workspace create time. Missing vars fail fast with the full
list, not lazily on first use.
Walkthrough
A guided tour from creating a workspace to snapshotting it. Each step builds on the previous one; you can copy them in order. For a runnable end-to-end version against a real multi-mount workspace (/s3, /gdrive, /gmail, /slack, /discord), see
examples/python/cross/README.md.
1. Source env and create a workspace
The YAML’s${...} placeholders resolve from your shell at create
time, so source your env first. The daemon auto-spawns on the first
create.
2. Inspect
list is one line per workspace; get returns the full mount and
session detail.
3. Run commands against your mounts
execute runs a shell command inside the workspace. Paths resolve
through the mount registry (/s3/... hits S3, / hits the RAM
backing, etc.).
4. Pipe stdin
When stdout isn’t a TTY, the CLI forwards stdin to the command automatically.5. Dry-run with provision
provision returns a ProvisionResult (network bytes, cache hits,
estimated cost) without running the command — handy for predicting
spend before kicking off an expensive read.
6. Cache: network → hit after a real read
After a realcat, provision flips that path from a network read
to a cache hit (cache_hits=1).
7. Session traces
Every session writes a JSONL trace under/.sessions/<utc-yyyy-mm-dd>/.
8. Background jobs
Long-running commands take--background and return a job_id
immediately. mirage job wait blocks until it’s done.
9. Snapshot to disk
10. Restore from snapshot
Snapshots redact cloud creds at save time, so loading needs fresh creds via--override. The same workspace YAML is a valid override.
--override is required for any mount whose resource declares
needs_override=True (S3, GDrive, Slack, Discord, Redis, …).
The snapshot stores "<REDACTED>" in place of secrets at save
time. Loading without --override 400s with the list of prefixes
that need fresh creds. Local resources (RAM, Disk) restore as-is
with no override needed.11. Clean up
The daemon exits ~30s after the last workspace is deleted.Verbs at a glance
| Verb | What it does |
|---|---|
mirage workspace create FILE [--id NAME] | Build resources from YAML, register a workspace, return its id. |
mirage workspace list | Brief one-line summary per active workspace. |
mirage workspace get ID [--verbose] | Full detail (mounts, sessions, optionally cache / dirty / history internals). |
mirage workspace delete ID | Stop the workspace; daemon may exit on the idle timer. |
mirage workspace clone ID [--id NAME] [--override FILE] | Fresh local backings, shared remote resources; partial-config override swaps creds or buckets. |
mirage workspace snapshot ID PATH.tar | Snapshot to a tar file. |
mirage workspace load PATH.tar [--id NAME] [--override FILE] | Restore from tar; override re-supplies redacted creds. |
mirage session create WS [--id NAME] | Add a named session (own cwd + env). |
mirage session list WS | List sessions for a workspace. |
mirage session delete WS SESSION | Close a session. |
mirage execute --workspace_id WS [--session_id S] [--background] --command "..." | Run a command. Pipes stdin automatically when stdout is not a TTY. |
mirage provision --workspace_id WS [--session_id S] --command "..." | Dry-run / cost estimate — returns a ProvisionResult shape (network bytes, cache hits, estimated cost) without running the command. |
mirage job list [--workspace_id WS] | List jobs the daemon has run, plus their status. |
mirage job get JOB | Detail for one job. |
mirage job wait JOB [--timeout SECS] | Block until the job is done; returns the result. |
mirage job cancel JOB | Cancel a running job. |
Daemon control
Most users never run these directly — the daemon auto-spawns on firstworkspace create and auto-exits after the idle timer fires
(default 30s after the last workspace is deleted). When you need to
intervene — typically during development, when you want code changes
to take effect:
| Verb | What it does |
|---|---|
mirage daemon status | Daemon health, PID, uptime, workspace count. Exit 1 if daemon not reachable. |
mirage daemon stop | POST /v1/shutdown to trip the daemon’s exit event. Daemon snapshots active workspaces (if persist_dir set), closes them, exits. Falls back to SIGTERM on --timeout. |
mirage daemon restart | Stop, then either wait for next workspace create to auto-spawn (default) or --eager to spawn immediately. Workspaces are LOST unless persist_dir is configured. |
mirage daemon kill | SIGKILL via PID file at ~/.mirage/daemon.pid. Skips graceful shutdown — use only when stop hangs. |
When you change Mirage’s source code (commands, providers, etc.),
the running daemon won’t see your changes — it loaded the old code
at startup. Run
mirage daemon restart to pick up new code.
Same situation as dockerd after recompiling Docker.Where the daemon lives
Most users never need to think about the daemon. If you do:- It listens on
http://127.0.0.1:8765by default. - Override via
MIRAGE_DAEMON_URLenv var or~/.mirage/config.toml: - Logs go to
~/.mirage/daemon.logwhen the CLI auto-spawns it. - It exits 30 seconds after the workspace count hits zero (configurable).