litestar-deployment
Auto-activate for Dockerfile, docker-compose.yml, railway.json, railway.toml, Procfile, cloudbuild.yaml, app.yaml, service.yaml, deploy.sh, systemd units, Kubernetes manifests, Terraform, or granian/litestar run in deployment context. Use when deploying Litestar apps to container
What it does
Litestar Deployment
Production deployment patterns for Litestar ASGI applications across Docker, Railway, Kubernetes/GKE, Cloud Run, and systemd. Covers multi-stage Dockerfiles, distroless images, asset pipelines, worker containers, and health-check integration.
All deployment paths use Granian (via litestar-granian) as the ASGI server, uv for Python package management, and Bun for frontend asset builds.
Build vs. deploy split: this skill is about running Litestar artifacts in production. For producing those artifacts — wheel bundling with embedded Vite assets, PyApp onefile binaries, GitHub Actions CI/release pipelines — see litestar-build.
Code Style Rules
from __future__ import annotationsis allowed in consumer-app modules (Dockerfiles, deploy scripts, settings).- All Python samples use PEP 604 unions (
T | None). - Granian over uvicorn in every CMD/entrypoint. Use
litestar run(which delegates to Granian whenlitestar-granianis installed). - Environment-driven configuration via
@dataclasssettings — never hardcode secrets or connection strings. - Shell scripts follow Google Shell Style Guide (set -euo pipefail, quoted variables).
Quick Reference
| Target | Reference | Key File |
|---|---|---|
| Docker (standard multi-stage) | references/docker-standard.md | Dockerfile |
| Docker (distroless production) | references/docker-distroless.md | Dockerfile.distroless |
| SAQ worker container | references/docker-workers.md | Dockerfile.worker |
| Docker Compose (app + infra) | references/docker-compose.md | docker-compose.yml |
| Railway | references/railway.md | railway.app.json |
| Kubernetes / GKE | references/kubernetes.md | deploy.py, templates/ |
| Cloud Run | references/cloud-run.md | service.yaml |
| systemd native | references/systemd.md | litestar.service |
Dockerfile CMD (all variants)
# Web server
ENTRYPOINT ["tini", "--"]
CMD ["litestar", "run", "--host", "0.0.0.0", "--port", "8000"]
# SAQ worker (separate container)
ENTRYPOINT ["tini", "--"]
CMD ["app", "workers", "run"]
Environment variables (required in every target)
LITESTAR_APP="app.server.asgi:create_app" # app discovery
DATABASE_URL="postgresql+asyncpg://..." # async driver
SAQ_REDIS_URL="redis://cache:6379/0" # worker queue
SECRET_KEY="..." # session signing
<workflow>
Workflow
Step 1: Choose deployment target
Docker Compose for local/staging. Railway for rapid PaaS. GKE/K8s for production at scale. Cloud Run for serverless containers. systemd for bare-metal.
Step 2: Write the Dockerfile
Start from Dockerfile.distroless for production (preferred). Use standard multi-stage for environments that need a shell. Use Dockerfile.dev for local Docker development. Always pin ARG PYTHON_VERSION=3.13.
Step 3: Build frontend assets inside Docker
Copy Bun lockfiles first (layer caching), install JS deps, then bun run build and uv run app assets build. Assets must be in the wheel before uv build.
Step 4: Create separate worker image
SAQ workers use the same build stages but a different CMD (app workers run). No port exposed, no health-check HTTP endpoint. Set SAQ_USE_SERVER_LIFESPAN=false.
Step 5: Set up CI/CD
Build images in CI, push to registry, deploy via railway up, gcloud run deploy, or kubectl apply. Tag images with git SHA for production — never deploy latest to prod.
Step 6: Configure health checks and monitoring
Expose /health on the API container. K8s uses startupProbe + livenessProbe + readinessProbe on /health:8000. Cloud Run and Railway use the same endpoint for readiness.
Guardrails
- Distroless for production, slim for dev. Distroless (
gcr.io/distroless/cc-debian12:nonroot) has no shell, no apt, minimal CVE surface. Use slim only when you need a shell for debugging. - Non-root user (UID 65532). Match the distroless
nonrootuser. Create withuseradd --system --uid 65532in standard images. - uv for all package installs. No pip, no pip-tools.
uv sync --frozen --no-devin builder,uv pip installwheel in runner. - UV_COMPILE_BYTECODE=1. Pre-compile .pyc in the builder — saves 200-500ms cold-start in containers.
- UV_LINK_MODE=copy. Hardlinks break on overlay filesystems. Always copy.
- Tini as PID 1. Containers need an init process for signal forwarding and zombie reaping.
ENTRYPOINT ["tini", "--"]. - STOPSIGNAL SIGINT. Granian handles SIGINT for graceful shutdown. Docker sends SIGTERM by default; set
STOPSIGNAL SIGINTor Granian ignores the signal and gets SIGKILL after timeout. - Multi-architecture support. Use
docker buildxwith--platform linux/amd64,linux/arm64. Distroless Dockerfile handles arch-specific lib paths viaTARGETARCH. - Asset build inside Docker. Vite/Bun builds run in the builder stage. Never mount host
node_modulesinto production images. - Health check endpoints. Every API container must expose
/health. K8s probes hit this path. Cloud Run and Railway use it for readiness. - LITESTAR_APP env var. Both Litestar CLI and Granian read this for app discovery. Set it in Dockerfile and override per-environment.
- Never run as root.
USER nonrootin Dockerfile.runAsNonRoot: truein K8s pod security context. - Pin Python version.
ARG PYTHON_VERSION=3.13at the top. Never usepython:latest. - Separate worker containers from web containers. SAQ workers poll Redis, not HTTP. They need different CMD, different scaling, and no port.
- Build-time env vars to prevent connection attempts. Set
DATABASE_POOL_DISABLED=true,SAQ_USE_SERVER_LIFESPAN=false,SAQ_WEB_ENABLED=falseduring build to prevent the app from trying to connect to databases during asset compilation.
Validation Checkpoint
Before shipping a Litestar deployment, verify:
- Dockerfile uses multi-stage build (python-base -> builder -> runner)
-
ARG PYTHON_VERSIONis pinned (notlatest) -
COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/present -
UV_COMPILE_BYTECODE=1andUV_LINK_MODE=copyset in builder - Frontend assets built inside Docker (not copied from host)
-
uv buildcreates wheel; runner installs wheel (not editable) - Runner uses non-root user (UID 65532)
-
ENTRYPOINT ["tini", "--"]set -
STOPSIGNAL SIGINTset (for Granian graceful shutdown) -
LITESTAR_APPenv var set -
/healthendpoint exists and is used by probes/readiness checks - SAQ worker is a separate container with different CMD, no EXPOSE
- No secrets in Dockerfile (use env vars or mounted secrets)
- Production image is distroless or has documented justification for slim
- Docker Compose
depends_onusescondition: service_healthy
Example
See references/docker-distroless.md for a complete 4-stage distroless Dockerfile with multi-arch support, Vite asset build, and non-root execution.
For a full local stack (app + worker + migrator + PostgreSQL + Valkey), see references/docker-compose.md.
For Kubernetes production deployment with HPA, Ingress, and GKE Workload Identity, see references/kubernetes.md.
</example>References Index
- Docker Standard Multi-Stage — slim-based Dockerfile with cache mounts
- Docker Distroless (Production) — preferred production image
- Docker Workers (SAQ) — background task container
- Docker Compose — full local/staging stack
- Railway — PaaS deployment with Redis provisioning
- Kubernetes / GKE — Deployment, Service, HPA, Ingress
- Cloud Run — serverless container deployment
- systemd Native — bare-metal service unit
Official References
- https://docs.litestar.dev/latest/usage/cli.html — Litestar CLI and
litestar run - https://docs.litestar.dev/latest/topics/deployment/index.html — Official deployment guide
- https://docs.railway.com/ — Railway platform docs
- https://cloud.google.com/run/docs — Cloud Run documentation
- https://cloud.google.com/kubernetes-engine/docs — GKE documentation
- https://www.freedesktop.org/software/systemd/man/systemd.service.html — systemd service units
- https://github.com/GoogleContainerTools/distroless — Distroless container images
Cross-References
- litestar-build — how the wheel and PyApp onefile artifacts this skill deploys are produced (Hatchling config, Vite-in-package bundling, GitHub release pipelines)
- litestar-granian — ASGI server tuning (workers, threads, HTTP/2, backpressure)
- litestar-saq — SAQ worker configuration and task definitions
- litestar-vite — Vite asset build pipeline and TypeGen
- litestar settings — env-driven
@dataclasssettings pattern
Shared Styleguide Baseline
Capabilities
Install
Quality
deterministic score 0.45 from registry signals: · indexed on github topic:agent-skills · 7 github stars · SKILL.md body (9,816 chars)