Skillquality 0.45

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

Price
free
Protocol
skill
Verified
no

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 annotations is 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 when litestar-granian is installed).
  • Environment-driven configuration via @dataclass settings — never hardcode secrets or connection strings.
  • Shell scripts follow Google Shell Style Guide (set -euo pipefail, quoted variables).

Quick Reference

TargetReferenceKey File
Docker (standard multi-stage)references/docker-standard.mdDockerfile
Docker (distroless production)references/docker-distroless.mdDockerfile.distroless
SAQ worker containerreferences/docker-workers.mdDockerfile.worker
Docker Compose (app + infra)references/docker-compose.mddocker-compose.yml
Railwayreferences/railway.mdrailway.app.json
Kubernetes / GKEreferences/kubernetes.mddeploy.py, templates/
Cloud Runreferences/cloud-run.mdservice.yaml
systemd nativereferences/systemd.mdlitestar.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.

</workflow> <guardrails>

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 nonroot user. Create with useradd --system --uid 65532 in standard images.
  • uv for all package installs. No pip, no pip-tools. uv sync --frozen --no-dev in builder, uv pip install wheel 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 SIGINT or Granian ignores the signal and gets SIGKILL after timeout.
  • Multi-architecture support. Use docker buildx with --platform linux/amd64,linux/arm64. Distroless Dockerfile handles arch-specific lib paths via TARGETARCH.
  • Asset build inside Docker. Vite/Bun builds run in the builder stage. Never mount host node_modules into 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 nonroot in Dockerfile. runAsNonRoot: true in K8s pod security context.
  • Pin Python version. ARG PYTHON_VERSION=3.13 at the top. Never use python: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=false during build to prevent the app from trying to connect to databases during asset compilation.
</guardrails> <validation>

Validation Checkpoint

Before shipping a Litestar deployment, verify:

  • Dockerfile uses multi-stage build (python-base -> builder -> runner)
  • ARG PYTHON_VERSION is pinned (not latest)
  • COPY --from=ghcr.io/astral-sh/uv:latest /uv /uvx /bin/ present
  • UV_COMPILE_BYTECODE=1 and UV_LINK_MODE=copy set in builder
  • Frontend assets built inside Docker (not copied from host)
  • uv build creates wheel; runner installs wheel (not editable)
  • Runner uses non-root user (UID 65532)
  • ENTRYPOINT ["tini", "--"] set
  • STOPSIGNAL SIGINT set (for Granian graceful shutdown)
  • LITESTAR_APP env var set
  • /health endpoint 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_on uses condition: service_healthy
</validation> <example>

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

Official References

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 @dataclass settings pattern

Shared Styleguide Baseline

Capabilities

skillsource-litestar-orgskill-litestar-deploymenttopic-advanced-alchemytopic-agent-skillstopic-agentskillstopic-ai-agentstopic-claude-code-plugintopic-claude-code-skillstopic-gemini-cli-extensiontopic-htmxtopic-inertiatopic-litestartopic-mcptopic-python

Install

Quality

0.45/ 1.00

deterministic score 0.45 from registry signals: · indexed on github topic:agent-skills · 7 github stars · SKILL.md body (9,816 chars)

Provenance

Indexed fromgithub
Enriched2026-05-18 19:13:53Z · deterministic:skill-github:v1 · v1
First seen2026-05-18
Last seen2026-05-18

Agent access