Files
TK-BOM-Project/docker-compose.yml
Hyungi Ahn 50570e4624
Some checks failed
SonarQube Analysis / SonarQube Scan (push) Has been cancelled
feat: 사용자 요구사항 기능 완전 구현 및 전체 카테고리 추가
- 사용자 요구사항 저장/로드/엑셀 내보내기 기능 완전 구현
- 백엔드 API 수정: Request Body 방식으로 변경
- 데이터베이스 스키마: material_id 컬럼 추가
- 프론트엔드 상태 관리 개선: 저장 후 자동 리로드
- 입력 필드 연결 문제 해결: 누락된 onChange 핸들러 추가
- NewMaterialsPage에 '전체' 카테고리 버튼 추가 (기본 선택)
- Docker 환경 개선: 프론트엔드 볼륨 마운트 및 포트 수정
- UI 개선: 벌레 이모지 제거, 디버그 코드 정리
2025-09-30 08:55:20 +09:00

124 lines
3.3 KiB
YAML

# TK-MP-Project Docker Compose 설정
# 기본 설정 (개발 환경 기준)
# version: '3.8' # Docker Compose v2에서는 version 필드가 선택사항
services:
# PostgreSQL 데이터베이스
postgres:
image: postgres:15-alpine
container_name: tk-mp-postgres
restart: unless-stopped
environment:
POSTGRES_DB: ${POSTGRES_DB:-tk_mp_bom}
POSTGRES_USER: ${POSTGRES_USER:-tkmp_user}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-tkmp_password_2025}
POSTGRES_INITDB_ARGS: "--encoding=UTF-8 --locale=C"
ports:
- "${POSTGRES_PORT:-5432}:5432"
volumes:
- postgres_data:/var/lib/postgresql/data
- ./database/init:/docker-entrypoint-initdb.d
networks:
- tk-mp-network
healthcheck:
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-tkmp_user} -d ${POSTGRES_DB:-tk_mp_bom}"]
interval: 30s
timeout: 10s
retries: 3
# Redis (캐시 및 세션 관리용)
redis:
image: redis:7-alpine
container_name: tk-mp-redis
restart: unless-stopped
ports:
- "${REDIS_PORT:-6379}:6379"
volumes:
- redis_data:/data
networks:
- tk-mp-network
healthcheck:
test: ["CMD", "redis-cli", "ping"]
interval: 30s
timeout: 10s
retries: 3
# 백엔드 FastAPI 서비스
backend:
build:
context: ./backend
dockerfile: Dockerfile
container_name: tk-mp-backend
restart: unless-stopped
ports:
- "${BACKEND_PORT:-18000}:8000"
environment:
- DATABASE_URL=postgresql://${POSTGRES_USER:-tkmp_user}:${POSTGRES_PASSWORD:-tkmp_password_2025}@postgres:5432/${POSTGRES_DB:-tk_mp_bom}
- REDIS_URL=redis://redis:6379
- ENVIRONMENT=${ENVIRONMENT:-development}
- DEBUG=${DEBUG:-true}
- PYTHONPATH=/app
depends_on:
- postgres
- redis
networks:
- tk-mp-network
volumes:
- ./backend/uploads:/app/uploads
# 개발 환경에서는 코드 변경 실시간 반영 (오버라이드에서 설정)
# healthcheck:
# test: ["CMD", "curl", "-f", "http://localhost:8000/health"]
# interval: 30s
# timeout: 10s
# retries: 3
# 프론트엔드 React + Nginx 서비스
frontend:
build:
context: ./frontend
dockerfile: Dockerfile
args:
- VITE_API_URL=${VITE_API_URL:-http://localhost:18000}
container_name: tk-mp-frontend
restart: unless-stopped
ports:
- "${FRONTEND_PORT:-13000}:5173"
environment:
- VITE_API_URL=${VITE_API_URL:-http://localhost:18000}
depends_on:
- backend
networks:
- tk-mp-network
# pgAdmin 웹 관리도구 (개발/테스트 환경용)
pgadmin:
image: dpage/pgadmin4:latest
container_name: tk-mp-pgadmin
restart: unless-stopped
environment:
PGADMIN_DEFAULT_EMAIL: ${PGADMIN_EMAIL:-admin@example.com}
PGLADMIN_DEFAULT_PASSWORD: ${PGADMIN_PASSWORD:-admin2025}
PGADMIN_CONFIG_SERVER_MODE: 'False'
ports:
- "${PGADMIN_PORT:-5050}:80"
volumes:
- pgadmin_data:/var/lib/pgadmin
depends_on:
- postgres
networks:
- tk-mp-network
profiles:
- dev
- test
volumes:
postgres_data:
driver: local
pgadmin_data:
driver: local
redis_data:
driver: local
networks:
tk-mp-network:
driver: bridge