2.1 KiB
2.1 KiB
Docker
Run 9Router in a container. Published image: decolua/9router — multi-platform linux/amd64 + linux/arm64.
👤 For Users
Quick start
docker run -d \
-p 20128:20128 \
-v "$HOME/.9router:/app/data" \
-e DATA_DIR=/app/data \
--name 9router \
decolua/9router:latest
App listens on port 20128. Open: http://localhost:20128
Manage container
docker logs -f 9router # view logs
docker stop 9router # stop
docker start 9router # start again
docker rm -f 9router # remove
Data persistence
-v "$HOME/.9router:/app/data" \
-e DATA_DIR=/app/data
Without DATA_DIR, the app falls back to ~/.9router/ (macOS/Linux) or %APPDATA%\9router\ (Windows). In the container, DATA_DIR=/app/data makes the bind mount work.
Data layout under $DATA_DIR/:
$DATA_DIR/
├── db/
│ ├── data.sqlite # main SQLite database
│ └── backups/ # auto backups
└── ... # certs, logs, runtime configs
Host path: $HOME/.9router/db/data.sqlite
Container path: /app/data/db/data.sqlite
Optional env vars
docker run -d \
-p 20128:20128 \
-v "$HOME/.9router:/app/data" \
-e DATA_DIR=/app/data \
-e PORT=20128 \
-e HOSTNAME=0.0.0.0 \
-e DEBUG=true \
--name 9router \
decolua/9router:latest
Update to latest
docker pull decolua/9router:latest
docker rm -f 9router
# re-run the quick start command
🛠 For Developers
Build image locally (test)
cd app && docker build -t 9router .
docker run --rm -p 20128:20128 \
-v "$HOME/.9router:/app/data" \
-e DATA_DIR=/app/data \
9router
Publish (automatic via CI)
Push a git tag v* → GitHub Actions builds multi-platform (amd64+arm64) and pushes to:
ghcr.io/decolua/9router:v{version}+:latestdecolua/9router:v{version}+:latest
# Use scripts/release.js (recommended)
node scripts/release.js "Release title" "Notes"
# Or manually
git tag v0.4.x && git push origin v0.4.x
Workflow: app/.github/workflows/docker-publish.yml