Skillshub nestjs-deployment
Docker builds, Memory tuning, and Graceful shutdown. Use when containerizing NestJS apps, tuning memory, or implementing graceful shutdown. (triggers: Dockerfile, k8s/**, helm/**, Dockerfile, max-old-space-size, shutdown hooks)
install
source · Clone the upstream repo
git clone https://github.com/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/HoangNguyen0403/agent-skills-standard/nestjs-deployment" ~/.claude/skills/comeonoliver-skillshub-nestjs-deployment && rm -rf "$T"
manifest:
skills/HoangNguyen0403/agent-skills-standard/nestjs-deployment/SKILL.mdsource content
Deployment & Ops Standards
Priority: P1 (OPERATIONAL)
Docker optimization and production deployment standards for NestJS applications.
Docker Optimization
- Multi-Stage Builds: Mandatory.
- Build Stage: Install
, build NestJS (devDependencies
).nest build - Run Stage: Copy only
anddist
(pruned), usenode_modules
.node:alpine
- Build Stage: Install
- Security: Do not run as
.root- Dockerfile:
.USER node
- Dockerfile:
Runtime Tuning (Node.js)
- Memory Config: Container memory != Node memory.
- Rule: Explicitly set Max Old Space.
- Command:
node --max-old-space-size=XXX dist/main - Calculation: Set to ~75-80% of Kubernetes Limit. (Limit: 1GB -> OldSpace: 800MB).
- Graceful Shutdown:
- Signal: Listen to
.SIGTERM - NestJS:
is mandatory.app.enableShutdownHooks() - Sleep: Add a "Pre-Stop" sleep in K8s (5-10s) to allow Load Balancer to drain connections before Node process stops accepting traffic.
- Signal: Listen to
Init Patterns
- Database Migrations:
- Anti-Pattern: Running migration in
on startup.main.ts - Pro Pattern: Use an Init Container in Kubernetes that runs
before the app container starts.npm run typeorm:migration:run
- Anti-Pattern: Running migration in
Environment Variables & CI/CD
- CI/CD Pipelines (GitHub, GitLab, Azure, etc.):
- If you modify
to add a new environment variable, you MUST map it explicitly in your deployment pipeline/infrastructure-as-code.src/config/env.validation.ts - Platform Context:
- Cloud Run/ECS: Variables must be explicitly passed in the service definition.
- Kubernetes: New variables must be added to the
manifest orDeployment
/ConfigMap
.Secret - Lambda/Serverless: Must be added to
or provider console.serverless.yml
- Fundamental Rule: Application code configuration changes are "breaking changes" for the infrastructure layer. Never assume environment inheritance.
- If you modify
Anti-Patterns
- No migrations in main.ts: Use K8s Init Containers or pre-deploy CI steps for migration runs.
- No root user in Docker: Always add
to Dockerfile; running as root is a security risk.USER node - No unbounded Node heap: Set
to ~75% of container memory limit.--max-old-space-size