skills/infra-docker/SKILL.md
Local development environment with Docker Compose for PostgreSQL and other services. This skill should be used when setting up local infrastructure, managing development databases, or configuring containerized services.
npx skillsauth add aussiegingersnap/cursor-skills infra-dockerInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Docker Compose patterns for local development environments including PostgreSQL and supporting services.
Create docker-compose.yml in project root:
services:
postgres:
image: postgres:16-alpine
container_name: myapp-postgres
restart: unless-stopped
environment:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: myapp
ports:
- "5432:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U postgres"]
interval: 5s
timeout: 5s
retries: 5
volumes:
postgres_data:
# Start services
docker compose up -d
# View logs
docker compose logs -f postgres
# Stop services
docker compose down
# Stop and remove volumes (reset database)
docker compose down -v
# Check status
docker compose ps
# Database
DATABASE_URL=postgres://postgres:postgres@localhost:5432/myapp
services:
postgres:
image: postgres:16-alpine
environment:
POSTGRES_USER: ${POSTGRES_USER:-postgres}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-postgres}
POSTGRES_DB: ${POSTGRES_DB:-myapp}
ports:
- "${POSTGRES_PORT:-5432}:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
volumes:
postgres_data:
services:
postgres:
image: postgres:16-alpine
container_name: myapp-postgres
restart: unless-stopped
environment:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: myapp
ports:
- "5432:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U postgres"]
interval: 5s
timeout: 5s
retries: 5
redis:
image: redis:7-alpine
container_name: myapp-redis
restart: unless-stopped
ports:
- "6379:6379"
volumes:
- redis_data:/data
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 5s
timeout: 5s
retries: 5
volumes:
postgres_data:
redis_data:
services:
postgres:
image: postgres:16-alpine
container_name: myapp-postgres
environment:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: postgres
POSTGRES_DB: myapp
ports:
- "5432:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
pgadmin:
image: dpage/pgadmin4:latest
container_name: myapp-pgadmin
environment:
PGADMIN_DEFAULT_EMAIL: [email protected]
PGADMIN_DEFAULT_PASSWORD: admin
PGADMIN_CONFIG_SERVER_MODE: "False"
ports:
- "5050:80"
volumes:
- pgadmin_data:/var/lib/pgadmin
depends_on:
- postgres
volumes:
postgres_data:
pgadmin_data:
Access pgAdmin at http://localhost:5050
services:
minio:
image: minio/minio:latest
container_name: myapp-minio
command: server /data --console-address ":9001"
environment:
MINIO_ROOT_USER: minioadmin
MINIO_ROOT_PASSWORD: minioadmin
ports:
- "9000:9000" # API
- "9001:9001" # Console
volumes:
- minio_data:/data
volumes:
minio_data:
Access Minio Console at http://localhost:9001
# Using Docker
docker compose exec postgres psql -U postgres -d myapp
# Direct connection (if psql installed locally)
psql postgres://postgres:postgres@localhost:5432/myapp
-- List databases
\l
-- Connect to database
\c myapp
-- List tables
\dt
-- Describe table
\d user
-- Show table data
SELECT * FROM "user" LIMIT 10;
-- Exit
\q
# Backup
docker compose exec postgres pg_dump -U postgres myapp > backup.sql
# Restore
docker compose exec -T postgres psql -U postgres myapp < backup.sql
# Backup specific tables
docker compose exec postgres pg_dump -U postgres -t user -t session myapp > users_backup.sql
# Drop and recreate
docker compose exec postgres psql -U postgres -c "DROP DATABASE IF EXISTS myapp;"
docker compose exec postgres psql -U postgres -c "CREATE DATABASE myapp;"
# Or restart with fresh volume
docker compose down -v
docker compose up -d
Add convenient scripts:
{
"scripts": {
"docker:up": "docker compose up -d",
"docker:down": "docker compose down",
"docker:reset": "docker compose down -v && docker compose up -d",
"docker:logs": "docker compose logs -f",
"docker:psql": "docker compose exec postgres psql -U postgres -d myapp",
"db:generate": "drizzle-kit generate",
"db:migrate": "tsx src/lib/db/migrate.ts",
"db:studio": "drizzle-kit studio",
"dev": "next dev",
"dev:full": "docker compose up -d && next dev"
}
}
# Start services (if not running)
npm run docker:up
# Run migrations (if schema changed)
npm run db:migrate
# Start dev server
npm run dev
# Generate migration
npm run db:generate
# Apply migration
npm run db:migrate
# Verify in Drizzle Studio
npm run db:studio
# Reset everything
npm run docker:reset
# Run migrations
npm run db:migrate
# Check container status
docker compose ps
# Expected output:
# NAME STATUS
# myapp-postgres Up (healthy)
# myapp-redis Up (healthy)
Script to wait for PostgreSQL before running commands:
#!/bin/bash
# wait-for-db.sh
echo "Waiting for PostgreSQL..."
until docker compose exec postgres pg_isready -U postgres > /dev/null 2>&1; do
sleep 1
done
echo "PostgreSQL is ready!"
# Find what's using port 5432
lsof -i :5432
# Kill the process or use a different port
# In docker-compose.yml:
ports:
- "5433:5432" # Map to different local port
# Check logs
docker compose logs postgres
# Common issues:
# - Port conflict: change port mapping
# - Volume permissions: docker compose down -v
# - Image pull failed: docker compose pull
# Verify container is running
docker compose ps
# Verify port mapping
docker compose port postgres 5432
# Test connection
docker compose exec postgres pg_isready -U postgres
# Pre-pull images
docker compose pull
# Check disk space
docker system df
# Clean up unused resources
docker system prune
Add to .gitignore:
# Docker volumes (if not using named volumes)
.docker-data/
# Local environment overrides
docker-compose.override.yml
This setup is for local development only. For production:
infra-aws skill for production deployment| Command | Purpose |
|---------|---------|
| docker compose up -d | Start services |
| docker compose down | Stop services |
| docker compose down -v | Stop and reset data |
| docker compose logs -f | View logs |
| docker compose ps | Check status |
| docker compose exec postgres psql -U postgres | Connect to DB |
tools
# Versioning Skill Semantic versioning automation based on conventional commits. Automatically manages version bumps, changelogs, and git tags using `standard-version`. ## When to Use - Before releasing a new version - When preparing a deployment - To generate/update CHANGELOG.md - When the user asks about version management - Setting up versioning for a new project ## Prerequisites - Conventional commits enforced (recommended: lefthook) - Node.js project with package.json ## Setup (One-Ti
tools
Theme generation with tweakcn for shadcn/ui and Magic UI animations. Use when setting up project themes, customizing color schemes, adding dark mode, or integrating animated components.
tools
shadcn/studio component library with MCP integration, theme generation, and block patterns. This skill should be used when building UI with shadcn components, selecting dashboard layouts, or generating landing pages. Canonical source for all shadcn-based work.
development
Enforce a precise, minimal design system inspired by Linear, Notion, and Stripe. Use this skill when building dashboards, admin interfaces, or any UI that needs Jony Ive-level precision - clean, modern, minimalist with taste. Every pixel matters.