返回技能列表

setup-compose-stack

pjt222
更新于 2 days ago
9 次查看
17
2
17
在 GitHub 上查看
文档api

关于

This Claude Skill generates Docker Compose configurations for common multi-service application stacks like web apps with databases, caches, and worker processes. It handles service orchestration, networking, volumes, health checks, and environment-specific profiles. Use it to quickly set up reproducible development environments or production-like local setups for complex applications.

快速安装

Claude Code

推荐
主要方式
npx skills add pjt222/agent-almanac -a claude-code
插件命令备选方式
/plugin add https://github.com/pjt222/agent-almanac
Git 克隆备选方式
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/setup-compose-stack

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档


name: setup-compose-stack description: > 为常见应用模式配置通用 Docker Compose 栈。涵盖 Web 应用 + 数据库 + 缓存 + 工作进程服务、命名卷、网络、健康检查、depends_on、环境管理和 profiles。适用于运行带数据库或缓存的 Web 应用、设置多服务开发环境、 在 API 旁编排后台工作进程,或跨团队创建可重现的多服务环境。 license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: containerization complexity: intermediate language: Docker tags: docker-compose, orchestration, postgres, redis, multi-service, health-checks locale: zh-CN source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16

配置 Compose 栈

为包含数据库、缓存和工作进程的多服务应用栈配置 Docker Compose。

适用场景

  • 运行带数据库和/或缓存的 Web 应用
  • 设置包含多个服务的开发环境
  • 在 API 旁编排后台工作进程
  • 需要跨团队的可重现多服务环境

输入

  • 必需:应用服务(语言、端口、入口点)
  • 必需:所需的支持服务(数据库、缓存、队列等)
  • 可选:开发与生产配置
  • 可选:自定义服务的现有 Dockerfile

步骤

第 1 步:定义核心栈

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 启动所有服务,应用等待数据库健康就绪。

第 2 步:添加健康检查

健康检查支持 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

第 3 步:配置网络

services:
  app:
    networks:
      - frontend
      - backend

  postgres:
    networks:
      - backend

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

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

这将数据库与直接外部访问隔离,同时应用桥接两个网络。

第 4 步:管理环境变量

创建 .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

第 5 步:添加工作进程服务

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

第 6 步:使用 Profiles 管理可选服务

services:
  app:
    # always starts
    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

第 7 步:创建开发覆盖文件

docker-compose.override.yml 会自动合并:

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

第 8 步:构建和运行

# Build all images
docker compose build

# Start in background
docker compose up -d

# View logs
docker compose logs -f app

# Check service status
docker compose ps

# Stop and remove
docker compose down

# Stop and remove volumes (full reset)
docker compose down -v

预期结果: 所有服务启动,健康检查通过,应用连接到数据库和缓存。

失败处理: 检查 docker compose logs <service>。常见问题:端口冲突、缺少环境变量、健康检查超时。

验证清单

  • docker compose up 无错误启动所有服务
  • 数据库和缓存的健康检查通过
  • 应用连接到所有依赖服务
  • 命名卷在重启后持久化数据
  • .env 已加入 git 忽略;.env.example 已提交
  • docker compose down 干净地停止所有服务
  • Profiles 将开发工具与生产服务分离

常见问题

  • 无健康检查:没有 condition: service_healthydepends_on 仅等待容器启动,而非就绪。
  • 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 - R 特定的 Docker Compose 配置
  • create-dockerfile - 编写 compose 引用的 Dockerfile
  • create-multistage-dockerfile - 为栈构建优化镜像
  • configure-nginx - 向栈添加 Nginx 反向代理

GitHub 仓库

pjt222/agent-almanac
路径: i18n/zh-CN/skills/setup-compose-stack
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

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节点的正确返回格式、数据访问方法和常见陷阱解决方案。

查看技能