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 참조
This commit is contained in:
169
synology_deployment/docker-compose.yml
Normal file
169
synology_deployment/docker-compose.yml
Normal file
@@ -0,0 +1,169 @@
|
||||
# 시놀로지 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
|
||||
Reference in New Issue
Block a user