Files
TK-FB-Project/synology_deployment/docker-compose.yml
Hyungi Ahn beaffcad49 fix: MySQL 8.0 호환성 문제 해결 - db.execute → db.query 변경
🔧 주요 변경사항:
- WorkAnalysis.js: getRecentWork() 함수에서 db.execute → db.query로 변경
- Redis 연결 설정: socket 방식으로 업데이트 (Redis v5+ 호환)
- Docker Compose: Redis 서비스 추가 및 네트워크 단순화

🎯 해결된 문제:
- 'Incorrect arguments to mysqld_stmt_execute' 오류 해결
- 시놀로지 MySQL 8.0 환경에서 파라미터 바인딩 호환성 문제 해결
- Redis 연결 실패 문제 해결

📋 참고사항:
- MySQL 8.0의 ONLY_FULL_GROUP_BY 모드와 Node.js 드라이버 호환성 문제
- db.execute vs db.query 차이점은 MYSQL_COMPATIBILITY_NOTES.md 참조
2025-11-05 15:18:01 +09:00

170 lines
3.8 KiB
YAML

# 시놀로지 NAS 923+ 배포용 Docker Compose
# TK-FB-Project - 테크니컬코리아 작업 관리 시스템
services:
# MySQL 데이터베이스
db:
image: mysql:8.0
container_name: tkfb_db_prod
restart: unless-stopped
environment:
MYSQL_ROOT_PASSWORD: tkfb2024!
MYSQL_DATABASE: hyungi
MYSQL_USER: hyungi_user
MYSQL_PASSWORD: hyungi_pass2024!
TZ: Asia/Seoul
ports:
- "3306:3306"
volumes:
- db_data:/var/lib/mysql
- ./init_db:/docker-entrypoint-initdb.d
- ./mysql_conf:/etc/mysql/conf.d
command: --default-authentication-plugin=mysql_native_password
healthcheck:
test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-u", "root", "-ptkfb2024!"]
timeout: 20s
retries: 10
networks:
- tkfb_network
# Redis 캐시 서버
redis:
image: redis:7-alpine
container_name: tkfb_redis_prod
restart: unless-stopped
environment:
TZ: Asia/Seoul
ports:
- "6379:6379"
volumes:
- redis_data:/data
command: redis-server --appendonly yes
healthcheck:
test: ["CMD", "redis-cli", "ping"]
timeout: 3s
retries: 5
networks:
- tkfb_network
# Node.js API 서버
api:
build: ./api
container_name: tkfb_api_prod
restart: unless-stopped
environment:
NODE_ENV: production
DB_HOST: db
DB_PORT: 3306
DB_NAME: hyungi
DB_USER: hyungi_user
DB_PASSWORD: hyungi_pass2024!
JWT_SECRET: tkfb_jwt_secret_2024_synology_prod
PORT: 3005
REDIS_HOST: redis
REDIS_PORT: 6379
TZ: Asia/Seoul
ports:
- "20005:3005"
volumes:
- api_logs:/usr/src/app/logs
- api_uploads:/usr/src/app/uploads
depends_on:
db:
condition: service_healthy
redis:
condition: service_healthy
networks:
- tkfb_network
# FastAPI 브리지 서버
fastapi:
build: ./fastapi-bridge
container_name: tkfb_fastapi_prod
restart: unless-stopped
environment:
PYTHONPATH: /app
TZ: Asia/Seoul
ports:
- "8000:8000"
volumes:
- fastapi_logs:/app/logs
depends_on:
- api
networks:
- tkfb_network
# Nginx 웹 서버
web:
image: nginx:alpine
container_name: tkfb_web_prod
restart: unless-stopped
ports:
- "20000:80"
volumes:
- ./web-ui:/usr/share/nginx/html
- ./nginx_conf/nginx.conf:/etc/nginx/nginx.conf
- ./nginx_conf/default.conf:/etc/nginx/conf.d/default.conf
depends_on:
- api
- fastapi
networks:
- tkfb_network
# phpMyAdmin (선택사항 - 개발/관리용)
phpmyadmin:
image: phpmyadmin/phpmyadmin
container_name: tkfb_phpmyadmin_prod
restart: unless-stopped
environment:
PMA_HOST: db
PMA_PORT: 3306
PMA_USER: root
PMA_PASSWORD: tkfb2024!
MYSQL_ROOT_PASSWORD: tkfb2024!
TZ: Asia/Seoul
ports:
- "8080:80"
depends_on:
db:
condition: service_healthy
networks:
- tkfb_network
# 네트워크 설정 (단순화)
networks:
tkfb_network:
driver: bridge
# 볼륨 설정 (시놀로지 SSD 최적화)
volumes:
db_data:
driver: local
driver_opts:
type: none
o: bind
device: /volume2/docker/tkfb/mysql_data
api_logs:
driver: local
driver_opts:
type: none
o: bind
device: /volume2/docker/tkfb/api_logs
api_uploads:
driver: local
driver_opts:
type: none
o: bind
device: /volume2/docker/tkfb/api_uploads
fastapi_logs:
driver: local
driver_opts:
type: none
o: bind
device: /volume2/docker/tkfb/fastapi_logs
redis_data:
driver: local
driver_opts:
type: none
o: bind
device: /volume2/docker/tkfb/redis_data