setup-docker-compose
关于
This skill sets up Docker Compose configurations for R development environments with database services like PostgreSQL and Redis. It handles persistent volumes, networking, and multi-container orchestration. Use it when running R applications alongside external services or managing complex development setups.
快速安装
Claude Code
推荐npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/setup-docker-compose在 Claude Code 中复制并粘贴此命令以安装该技能
技能文档
name: setup-docker-compose locale: es source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16 description: > Configurar Docker Compose para entornos R con servicios de base de datos, volúmenes persistentes y redes. Usar cuando se necesite ejecutar aplicaciones R junto con PostgreSQL, Redis u otros servicios, o cuando se gestionen entornos de desarrollo multi-contenedor. license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: containerization complexity: basic language: multi tags: docker-compose, r, multi-container, orchestration
Configurar Docker Compose
Configurar Docker Compose para orquestar entornos R multi-contenedor con servicios y redes.
Cuándo Usar
- Ejecutando aplicaciones R con servicios de base de datos (PostgreSQL, MySQL)
- Configurando entornos de desarrollo con múltiples contenedores
- Orquestando aplicaciones Shiny con servicios de soporte
- Creando pipelines de análisis reproducibles con dependencias externas
- Gestionando servicios interconectados para proyectos de ciencia de datos
Entradas
- Requerido: Dockerfile para la aplicación R
- Requerido: Lista de servicios necesarios (base de datos, caché, etc.)
- Opcional: Archivos de configuración para cada servicio
- Opcional: Esquemas de base de datos o scripts de inicialización
- Opcional: Variables de entorno específicas por servicio
Procedimiento
Paso 1: Crear Estructura del Proyecto
Organizar archivos del proyecto para Docker Compose.
mkdir -p mi-proyecto/{app,db/init,config}
cd mi-proyecto
# Estructura:
# mi-proyecto/
# docker-compose.yml
# app/
# Dockerfile
# renv.lock
# app.R
# db/
# init/
# 01-schema.sql
# config/
# .Renviron
Esperado: Estructura de directorios creada con separación clara entre servicios.
En caso de fallo: Verificar permisos de escritura, asegurar que los paths no contienen caracteres especiales.
Paso 2: Escribir docker-compose.yml
Definir servicios, redes y volúmenes.
version: '3.8'
services:
app:
build:
context: ./app
dockerfile: Dockerfile
ports:
- "3838:3838"
environment:
- DB_HOST=db
- DB_PORT=5432
- DB_NAME=mibase
- DB_USER=postgres
- DB_PASSWORD=secreto
depends_on:
db:
condition: service_healthy
volumes:
- ./app:/app
- r-libs:/usr/local/lib/R/site-library
networks:
- app-network
db:
image: postgres:16
environment:
POSTGRES_DB: mibase
POSTGRES_USER: postgres
POSTGRES_PASSWORD: secreto
volumes:
- postgres-data:/var/lib/postgresql/data
- ./db/init:/docker-entrypoint-initdb.d
healthcheck:
test: ["CMD-SHELL", "pg_isready -U postgres"]
interval: 10s
timeout: 5s
retries: 5
networks:
- app-network
volumes:
postgres-data:
r-libs:
networks:
app-network:
driver: bridge
Esperado: Los servicios se definen con dependencias claras, healthchecks configurados, volúmenes para persistencia.
En caso de fallo: Validar sintaxis YAML, verificar que las imágenes existen en Docker Hub, comprobar que los puertos no están en uso.
Paso 3: Configurar Variables de Entorno
Usar archivos .env para configuración sensible.
# .env (gitignored)
POSTGRES_PASSWORD=mi_secreto_seguro
DB_NAME=mibase
SHINY_PORT=3838
# docker-compose.yml - referenciar variables
services:
db:
environment:
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
Esperado: Variables de entorno separadas del código, archivo .env excluido de Git.
En caso de fallo: Verificar que .env está en .gitignore, comprobar sintaxis de variables con docker compose config.
Paso 4: Iniciar y Verificar Servicios
Compilar y ejecutar todos los servicios.
# Compilar e iniciar
docker compose up -d --build
# Verificar estado
docker compose ps
# Ver logs
docker compose logs -f app
# Verificar conectividad de red
docker compose exec app R -e "DBI::dbConnect(RPostgres::Postgres(), host='db', dbname='mibase')"
# Detener servicios
docker compose down
# Detener y eliminar volúmenes
docker compose down -v
Esperado: Todos los servicios en estado saludable, la aplicación R se conecta a la base de datos, los logs no muestran errores.
En caso de fallo: Revisar logs de servicios individuales (docker compose logs db), verificar healthchecks, comprobar resolución DNS entre contenedores.
Validación
-
docker compose upinicia todos los servicios sin errores - La aplicación R se conecta exitosamente a los servicios dependientes
- Los volúmenes persisten datos entre reinicios
- Los healthchecks reportan servicios saludables
- Las variables de entorno se inyectan correctamente
- La red permite comunicación entre servicios
Errores Comunes
- Orden de inicio incorrecto: Usar
depends_onconcondition: service_healthyen lugar de solodepends_on. - Datos perdidos al detener: Usar volúmenes nombrados, no binds anónimos, para datos persistentes.
- Conexión rechazada entre servicios: Usar nombres de servicio como hostnames, no
localhost. - Puerto ya en uso: Verificar puertos disponibles antes de iniciar, usar puertos alternativos si es necesario.
- Credenciales en repositorio: Nunca commit de archivos .env con secretos reales.
Habilidades Relacionadas
create-r-dockerfile- Crear Dockerfiles base para aplicaciones Rsetup-compose-stack- Stacks Docker Compose generales multi-serviciooptimize-docker-build-cache- Optimizar tiempos de compilación Docker
GitHub 仓库
相关推荐技能
railway-docs
文档Railway Docs Skill可实时获取最新的Railway官方文档,确保回答的准确性。当开发者询问Railway功能特性、工作原理或分享docs.railway.com链接时,应优先使用此技能。它通过专门的LLM优化文档源提供最新信息,避免依赖过时记忆来回答技术问题。
n8n-code-python
文档该Skill为在n8n平台的Python代码节点中编写代码提供专家指导,特别适用于需要使用_input/_json/_node语法、Python标准库或了解n8n中Python限制的场景。它强调JavaScript应作为首选方案,仅当需要特定Python功能或对Python语法更熟悉时才使用Python。Skill提供了快速入门模板和关键注意事项,帮助开发者在n8n中高效编写Python代码。
archon
文档Archon Skill为开发者提供了基于RAG的语义搜索和项目任务管理功能,可通过REST API访问知识库。它支持文档搜索、网站爬取、文件上传和版本控制,适用于技术文档查询和项目管理场景。首次使用时需要配置Archon主机地址,建议在处理外部文档时优先使用该Skill。
n8n-code-javascript
文档这个Skill为n8n工作流中的JavaScript代码节点提供专业指导,涵盖数据处理、HTTP请求和日期操作等核心场景。它详细解释了如何正确使用n8n特有的`$input`/`$json`语法、`$helpers`工具以及DateTime对象,并包含关键的错误排查和模式选择建议。开发者通过该Skill能快速掌握Code节点的正确返回格式、数据访问方法和常见陷阱解决方案。
