MCP HubMCP Hub
Volver a habilidades

setup-compose-stack

pjt222
Actualizado 6 days ago
16 vistas
17
2
17
Ver en GitHub
Metaapidata

Acerca de

Esta habilidad de Claude ayuda a los desarrolladores a configurar pilas de Docker Compose para patrones comunes de aplicaciones multiservicio, como aplicaciones web con bases de datos, cachés y workers. Cubre características esenciales de orquestación, incluyendo volúmenes nombrados, redes, comprobaciones de salud y gestión de variables de entorno. Úsala al configurar entornos de desarrollo reproducibles o al orquestar servicios similares a producción entre equipos.

Instalación rápida

Claude Code

Recomendado
Principal
npx skills add pjt222/agent-almanac -a claude-code
Comando PluginAlternativo
/plugin add https://github.com/pjt222/agent-almanac
Git CloneAlternativo
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/setup-compose-stack

Copia y pega este comando en Claude Code para instalar esta habilidad

Documentación

設 Compose 棧

配 Docker Compose 為多服應棧含庫、緩、工。

  • 行網應含庫/緩→用
  • 設多服開境→用
  • 排背工於 API 旁→用
  • 跨組需可重多服境→用

  • :應服(語、口、入點)
  • :所需輔服(庫、緩、隊等)
  • :開 vs 產配
  • :自服既 Dockerfile

一:定核棧

services:
  app:
    build:
      context: .
      dockerfile: Dockerfile
    ports:
      - "3000:3000"
    environment:
      DATABASE_URL: postgres://appuser:apppass@postgres:5432/appdb
      REDIS_URL: redis://redis:6379
    depends_on:
      postgres:
        condition: service_healthy
      redis:
        condition: service_started
    restart: unless-stopped

  postgres:
    image: postgres:16
    environment:
      POSTGRES_DB: appdb
      POSTGRES_USER: appuser
      POSTGRES_PASSWORD: apppass
    volumes:
      - pgdata:/var/lib/postgresql/data
    ports:
      - "5432:5432"
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U appuser -d appdb"]
      interval: 5s
      timeout: 5s
      retries: 5

  redis:
    image: redis:7-alpine
    ports:
      - "6379:6379"
    volumes:
      - redisdata:/data

volumes:
  pgdata:
  redisdata:

得:docker compose up 啟諸服、應待健庫。

二:加健察

健察使 depends_on 能用 condition: service_healthy

services:
  postgres:
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U appuser -d appdb"]
      interval: 5s
      timeout: 5s
      retries: 5

  redis:
    healthcheck:
      test: ["CMD", "redis-cli", "ping"]
      interval: 5s
      timeout: 3s
      retries: 5

  app:
    healthcheck:
      test: ["CMD", "curl", "-f", "http://localhost:3000/health"]
      interval: 10s
      timeout: 5s
      retries: 3
      start_period: 10s

三:配網

services:
  app:
    networks:
      - frontend
      - backend

  postgres:
    networks:
      - backend

  nginx:
    networks:
      - frontend
    ports:
      - "80:80"

networks:
  frontend:
    driver: bridge
  backend:
    driver: bridge

此隔庫於直外達、應跨兩網。

四:管環變

.env(git 忽):

POSTGRES_PASSWORD=secure_password_here
APP_SECRET=your_secret_key

於 compose 用:

services:
  postgres:
    environment:
      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
  app:
    env_file:
      - .env

.env.example(提至 git):

POSTGRES_PASSWORD=changeme
APP_SECRET=changeme

五:加工服

services:
  worker:
    build:
      context: .
      dockerfile: Dockerfile
    command: ["node", "src/worker.js"]
    environment:
      DATABASE_URL: postgres://appuser:apppass@postgres:5432/appdb
      REDIS_URL: redis://redis:6379
    depends_on:
      postgres:
        condition: service_healthy
      redis:
        condition: service_started
    restart: unless-stopped
    deploy:
      replicas: 2

六:用組為可選服

services:
  app:
    build: .

  mailhog:
    image: mailhog/mailhog
    ports:
      - "8025:8025"
    profiles:
      - dev

  adminer:
    image: adminer
    ports:
      - "8080:8080"
    profiles:
      - dev
# Start core services only
docker compose up

# Start with dev tools
docker compose --profile dev up

七:建覆為開

docker-compose.override.yml 自合:

services:
  app:
    build:
      target: dev
    volumes:
      - .:/app
      - /app/node_modules
    environment:
      NODE_ENV: development
      DEBUG: "app:*"
    command: ["npm", "run", "dev"]

八:建行

docker compose build

docker compose up -d

docker compose logs -f app

docker compose ps

docker compose down

docker compose down -v

得:諸服啟、健察過、應連庫與緩。

敗:察 docker compose logs <service>。常題:口衝、缺環變、健察超時。

  • docker compose up 啟諸服無誤
  • 庫與緩健察過
  • 應連諸依服
  • 名卷跨啟保資
  • .env git 忽、.env.example
  • docker compose down 潔停諸
  • 組分開工於產服

  • 無健察depends_oncondition: service_healthy 僅待容啟、非備
  • 硬碼密於 compose:用 .env 或 Docker secrets。永勿提密
  • 卷掛覆:掛 .:/app 覆像內 node_modules。用匿卷:/app/node_modules
  • 口衝:察 docker compose pslsof -i :<port>
  • version::Compose V2 忽 version:。今設略之
  • WSL 徑問題:自 WSL 掛 Windows 目用 /mnt/c/...

  • setup-docker-compose
  • create-dockerfile
  • create-multistage-dockerfile
  • configure-nginx

Repositorio GitHub

pjt222/agent-almanac
Ruta: i18n/wenyan-ultra/skills/setup-compose-stack
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

Habilidades relacionadas

content-collections

Meta

Esta habilidad proporciona una configuración probada en producción para Content Collections, una herramienta centrada en TypeScript que transforma archivos Markdown/MDX en colecciones de datos con tipado seguro mediante validación Zod. Úsala al construir blogs, sitios de documentación o aplicaciones Vite + React con mucho contenido para garantizar seguridad de tipos y validación automática de contenido. Abarca todo, desde la configuración del plugin de Vite y compilación MDX hasta la optimización de despliegue y validación de esquemas.

Ver habilidad

polymarket

Meta

Esta habilidad permite a los desarrolladores crear aplicaciones con la plataforma de mercados de predicción Polymarket, incluyendo la integración de API para operaciones y datos de mercado. También proporciona transmisión de datos en tiempo real a través de WebSocket para monitorear operaciones en vivo y actividad del mercado. Úsela para implementar estrategias de trading o crear herramientas que procesen actualizaciones de mercado en tiempo real.

Ver habilidad

creating-opencode-plugins

Meta

Esta habilidad ayuda a los desarrolladores a crear complementos de OpenCode que se conectan a más de 25 tipos de eventos, como comandos, archivos y operaciones LSP. Proporciona la estructura del complemento, las especificaciones de la API de eventos y los patrones de implementación para módulos en JavaScript/TypeScript. Úsala cuando necesites interceptar, monitorear o extender el ciclo de vida del asistente de IA de OpenCode con lógica personalizada basada en eventos.

Ver habilidad

sglang

Meta

SGLang es un framework de alto rendimiento para el servicio de LLM que se especializa en generación rápida y estructurada para JSON, expresiones regulares y flujos de trabajo de agentes utilizando su caché de prefijos RadixAttention. Ofrece una inferencia significativamente más rápida, especialmente para tareas con prefijos repetidos, lo que lo hace ideal para salidas complejas y estructuradas, y conversaciones multiturno. Elige SGLang sobre alternativas como vLLM cuando necesites decodificación restringida o estés construyendo aplicaciones con uso extensivo de prefijos compartidos.

Ver habilidad