Use Cases

Docker Compose:Claude Code 实战指南

了解docker compose:Claude Code 实战. 包含实用技巧和代码示例。

Docker Composeで再現性のある开发环境を构建する

Docker Composeは複数の容器を定義・管理するツールで、开发环境の构建を大幅に效率化可以。Claude Code サービス结构の设计からDockerfileの优化まで、基础设施结构もスムーズにサポートします。

全栈开发环境の结构

让 Claude Code项目全体の结构を依頼吧。

> Next.js + PostgreSQL + Redisの开发环境をDocker Composeで构建して。
> 热重载支持、初期数据投入、ヘルスチェック付きで。
# docker-compose.yml
version: "3.9"

services:
  app:
    build:
      context: .
      dockerfile: Dockerfile.dev
    ports:
      - "3000:3000"
    volumes:
      - .:/app
      - /app/node_modules
      - /app/.next
    environment:
      - DATABASE_URL=postgresql://postgres:password@db:5432/myapp
      - REDIS_URL=redis://redis:6379
      - NODE_ENV=development
    depends_on:
      db:
        condition: service_healthy
      redis:
        condition: service_healthy
    command: npm run dev

  db:
    image: postgres:16-alpine
    ports:
      - "5432:5432"
    environment:
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: password
      POSTGRES_DB: myapp
    volumes:
      - postgres_data:/var/lib/postgresql/data
      - ./docker/init.sql:/docker-entrypoint-initdb.d/init.sql
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 5s
      timeout: 5s
      retries: 5

  redis:
    image: redis:7-alpine
    ports:
      - "6379:6379"
    volumes:
      - redis_data:/data
    healthcheck:
      test: ["CMD", "redis-cli", "ping"]
      interval: 5s
      timeout: 5s
      retries: 5

  mailhog:
    image: mailhog/mailhog
    ports:
      - "1025:1025"
      - "8025:8025"

volumes:
  postgres_data:
  redis_data:

开发用Dockerfileの优化

热重载に支持した开发用Dockerfileです。

# Dockerfile.dev
FROM node:20-alpine

WORKDIR /app

# パッケージファイルのみ先にコピーしてキャッシュ活用
COPY package.json package-lock.json ./
RUN npm ci

# ソースコードはボリュームマウントで共有
# COPYは不要(docker-compose.ymlで設定済み)

EXPOSE 3000

CMD ["npm", "run", "dev"]

本番用マルチステージ构建

本番部署用の优化されたDockerfileです。

# Dockerfile
# ステージ1: 依存関係のインストール
FROM node:20-alpine AS deps
WORKDIR /app
COPY package.json package-lock.json ./
RUN npm ci --production=false

# ステージ2: ビルド
FROM node:20-alpine AS builder
WORKDIR /app
COPY --from=deps /app/node_modules ./node_modules
COPY . .
RUN npm run build

# ステージ3: 本番イメージ
FROM node:20-alpine AS runner
WORKDIR /app

RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 nextjs

COPY --from=builder /app/public ./public
COPY --from=builder --chown=nextjs:nodejs /app/.next/standalone ./
COPY --from=builder --chown=nextjs:nodejs /app/.next/static ./.next/static

USER nextjs
EXPOSE 3000
ENV PORT 3000

CMD ["node", "server.js"]

環境別の结构文件分離

开发・测试・本番で配置を分離するパターンです。

# docker-compose.override.yml(開発環境用、自動読み込み)
services:
  app:
    volumes:
      - .:/app
      - /app/node_modules
    environment:
      - DEBUG=true
      - LOG_LEVEL=debug

  db:
    ports:
      - "5432:5432"

  adminer:
    image: adminer
    ports:
      - "8080:8080"
    depends_on:
      - db
# docker-compose.test.yml
services:
  app:
    build:
      context: .
      dockerfile: Dockerfile.dev
    environment:
      - DATABASE_URL=postgresql://postgres:password@db:5432/myapp_test
      - NODE_ENV=test
    command: npm run test:ci
    depends_on:
      db:
        condition: service_healthy

  db:
    image: postgres:16-alpine
    environment:
      POSTGRES_DB: myapp_test
      POSTGRES_USER: postgres
      POSTGRES_PASSWORD: password
    tmpfs:
      - /var/lib/postgresql/data
    healthcheck:
      test: ["CMD-SHELL", "pg_isready -U postgres"]
      interval: 3s
      timeout: 3s
      retries: 10

Makefileでコマンドを簡略化

よく使うコマンドをMakefileにまとめます。

.PHONY: up down build logs db-shell db-migrate db-seed test

up:
	docker compose up -d

down:
	docker compose down

build:
	docker compose build --no-cache

logs:
	docker compose logs -f app

db-shell:
	docker compose exec db psql -U postgres -d myapp

db-migrate:
	docker compose exec app npx prisma migrate dev

db-seed:
	docker compose exec app npx prisma db seed

test:
	docker compose -f docker-compose.yml -f docker-compose.test.yml run --rm app

clean:
	docker compose down -v --remove-orphans

总结

Docker Composeを使えば、チーム全員が同じ开发环境を簡単に再現可以。Claude Codeを活用すれば、サービス结构、Dockerfile优化、環境分離などの基础设施配置を高效地构建是可能的。

容器化された开发环境のさらなる集成はDev Container配置指南を、CI/CD流水线との联动はCI/CDセットアップ指南Docker Compose官方文档也建议确认一下。

#Claude Code #Docker #Docker Compose #開発環境 #infrastructure