feat: 데이터베이스 및 웹 UI 대규모 리팩토링
- 삭제된 DB 테이블들과 관련 코드 정리: * 12개 사용하지 않는 테이블 삭제 (activity_logs, CuttingPlan, DailyIssueReports 등) * 관련 모델, 컨트롤러, 라우트 파일들 삭제 * index.js에서 삭제된 라우트들 제거 - 웹 UI 페이지 정리: * 21개 사용하지 않는 페이지 삭제 * issue-reports 폴더 전체 삭제 * 모든 사용자 권한을 그룹장 대시보드로 통일 - 데이터베이스 스키마 정리: * v1 스키마로 통일 (daily_work_reports 테이블) * JSON 데이터 임포트 스크립트 구현 * 외래키 관계 정리 및 데이터 일관성 확보 - 통합 Docker Compose 설정: * 모든 서비스를 단일 docker-compose.yml로 통합 * 20000번대 포트 유지 * JWT 시크릿 및 환경변수 설정 - 문서화: * DATABASE_SCHEMA.md: 현재 DB 스키마 문서화 * DELETED_TABLES.md: 삭제된 테이블 목록 * DELETED_PAGES.md: 삭제된 페이지 목록
This commit is contained in:
120
docker-compose.yml.new
Normal file
120
docker-compose.yml.new
Normal file
@@ -0,0 +1,120 @@
|
||||
version: "3.8"
|
||||
|
||||
services:
|
||||
# MariaDB 데이터베이스
|
||||
db:
|
||||
image: mariadb:10.9
|
||||
container_name: tkfb_db
|
||||
restart: unless-stopped
|
||||
environment:
|
||||
- MYSQL_ROOT_PASSWORD=tkfb2024!
|
||||
- MYSQL_DATABASE=hyungi
|
||||
- MYSQL_USER=hyungi_user
|
||||
- MYSQL_PASSWORD=hyungi2024!
|
||||
volumes:
|
||||
- db_data:/var/lib/mysql
|
||||
- ./api.hyungi.net/migrations:/docker-entrypoint-initdb.d
|
||||
ports:
|
||||
- "20306:3306"
|
||||
healthcheck:
|
||||
test: ["CMD", "mysqladmin", "ping", "-h", "localhost"]
|
||||
timeout: 20s
|
||||
retries: 10
|
||||
networks:
|
||||
- tkfb_network
|
||||
|
||||
# Node.js API 서버
|
||||
api:
|
||||
build:
|
||||
context: ./api.hyungi.net
|
||||
dockerfile: Dockerfile
|
||||
container_name: tkfb_api
|
||||
depends_on:
|
||||
db:
|
||||
condition: service_healthy
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "20005:3005"
|
||||
environment:
|
||||
- NODE_ENV=production
|
||||
- PORT=3005
|
||||
- DB_HOST=db
|
||||
- DB_PORT=3306
|
||||
- DB_USER=hyungi_user
|
||||
- DB_PASSWORD=hyungi2024!
|
||||
- DB_NAME=hyungi
|
||||
- DB_ROOT_PASSWORD=tkfb2024!
|
||||
- JWT_SECRET=tkfb_jwt_secret_2024_hyungi_secure_key
|
||||
volumes:
|
||||
- ./api.hyungi.net/public/img:/usr/src/app/public/img:ro
|
||||
- ./api.hyungi.net/uploads:/usr/src/app/uploads
|
||||
- ./api.hyungi.net/logs:/usr/src/app/logs
|
||||
- ./api.hyungi.net/routes:/usr/src/app/routes
|
||||
- ./api.hyungi.net/controllers:/usr/src/app/controllers
|
||||
- ./api.hyungi.net/models:/usr/src/app/models
|
||||
- ./api.hyungi.net/index.js:/usr/src/app/index.js
|
||||
logging:
|
||||
driver: "json-file"
|
||||
options:
|
||||
max-size: "10m"
|
||||
max-file: "3"
|
||||
networks:
|
||||
- tkfb_network
|
||||
|
||||
# Web UI (Nginx)
|
||||
web:
|
||||
build:
|
||||
context: ./web-ui
|
||||
dockerfile: Dockerfile
|
||||
container_name: tkfb_web
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "20000:80"
|
||||
volumes:
|
||||
- ./web-ui:/usr/share/nginx/html:ro
|
||||
depends_on:
|
||||
- api
|
||||
networks:
|
||||
- tkfb_network
|
||||
|
||||
# FastAPI Bridge
|
||||
fastapi:
|
||||
build:
|
||||
context: ./fastapi-bridge
|
||||
dockerfile: Dockerfile
|
||||
container_name: tkfb_fastapi
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "20008:8000"
|
||||
environment:
|
||||
- API_BASE_URL=http://api:3005
|
||||
depends_on:
|
||||
- api
|
||||
networks:
|
||||
- tkfb_network
|
||||
|
||||
# phpMyAdmin
|
||||
phpmyadmin:
|
||||
image: phpmyadmin/phpmyadmin:latest
|
||||
container_name: tkfb_phpmyadmin
|
||||
depends_on:
|
||||
- db
|
||||
restart: unless-stopped
|
||||
ports:
|
||||
- "20080:80"
|
||||
environment:
|
||||
- PMA_HOST=db
|
||||
- PMA_USER=root
|
||||
- PMA_PASSWORD=tkfb2024!
|
||||
- UPLOAD_LIMIT=50M
|
||||
networks:
|
||||
- tkfb_network
|
||||
|
||||
volumes:
|
||||
db_data:
|
||||
driver: local
|
||||
|
||||
networks:
|
||||
tkfb_network:
|
||||
driver: bridge
|
||||
name: tkfb_network
|
||||
Reference in New Issue
Block a user