Files
invyone/docker/dev/docker-compose.invyone.yml
T
gbpark e70267f738
Build & Deploy to K8s / build-and-deploy (push) Failing after 1m14s
feat: SCADA 데모 음성 인식 + 경고 버튼 디자인 통일
- 음성 인식 (scada-demo/js/voice.js) — 한국어 발화 → 키워드 매핑 → INVYONE_UI.select()
  · 사이드바 마이크 버튼 + transcript 라벨, 매칭 시 청록 펄스
  · Chrome/Edge HTTPS 환경 (운영 siflex.invyone.com OK)
- 경고시스템/다중경고 버튼을 음성 인식과 동일 톤
  · 🚨 emoji → SVG 삼각형 아이콘, voice-btn 패턴 (다크 솔리드 + 컬러 액센트)
  · 정적 (반짝 펄스 애니메이션 제거)
- client.ts stash pop conflict 정리 (DEV_TENANT_HOST + 도메인 정리 통합)
- ui.js 다중 경고 시연 wiring + scada 작업 노트 2건
- 기타 syncthing 보류분 batch (대시보드/레이아웃/로그인 layout 정리)

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-03 05:39:43 +09:00

90 lines
3.3 KiB
YAML

name: invyone
# invyone (= 옛 TEST-VEX, React + Java 풀스택) 도커 컴포즈
# 사무실 우분투 호스팅용. restart unless-stopped 로 항상 떠있게.
#
# 외부 노출 포트:
# - frontend : 9772
# - backend-spring : 8083
#
# 컨테이너 내부 포트는 각 앱의 기본값 유지 (3000 / 8081)
# 모드: dev (volume mount + 자동 리로드). 코드 변경은 syncthing 통해 동기화됨.
#
# 띄우기:
# cd ~/invyone && docker compose -f docker/dev/docker-compose.invyone.yml up -d
#
# 끄기:
# cd ~/invyone && docker compose -f docker/dev/docker-compose.invyone.yml down
services:
# ========================
# Spring Boot 백엔드
# ========================
backend-spring:
image: invyone-backend-spring
build:
context: ../../backend-spring
dockerfile: ../docker/dev/backend-spring.Dockerfile
container_name: invyone-backend-spring
ports:
- "8083:8081"
environment:
SPRING_PROFILES_ACTIVE: dev
SERVER_PORT: 8081
# DB 연결 정보는 backend-spring/src/main/resources/application.yml 사용 (단일 소스).
# env 로 override 하고 싶으면 여기에 SPRING_DATASOURCE_URL/USERNAME/PASSWORD 를 다시 추가.
# JWT_SECRET 은 docker/dev/.env 에서 주입 (이 파일은 git 추적, .env 는 gitignored + syncthing 동기화)
JWT_SECRET: ${JWT_SECRET:?JWT_SECRET 환경변수 필요. docker/dev/.env 파일 확인}
JWT_EXPIRATION: ${JWT_EXPIRATION:-86400000}
CORS_ALLOWED_ORIGINS: ${CORS_ALLOWED_ORIGINS:-http://localhost:3000,http://localhost:9772,http://100.126.230.80:9772,http://*.invyone.com:[*],https://*.invyone.com:[*],http://*.invyone.com,https://*.invyone.com,http://*.nip.io:[*],http://*.sslip.io:[*]}
FILE_UPLOAD_DIR: ./uploads
volumes:
- ../../backend-spring:/app
networks:
- invyone-net
restart: unless-stopped
healthcheck:
# actuator 미설치 + spring security 가 / 와 /health 모두 403 처리.
# 컨테이너 내부에서 8081 포트로 응답이 오기만 하면 (status 무관) OK 로 간주.
test: ["CMD-SHELL", "curl -sS -o /dev/null http://localhost:8081/ || exit 1"]
interval: 30s
timeout: 10s
retries: 3
start_period: 120s
# ========================
# Next.js 프론트엔드
# ========================
frontend:
image: invyone-frontend
build:
context: ../../frontend
dockerfile: ../docker/dev/frontend.Dockerfile
container_name: invyone-frontend
ports:
- "9772:3000"
environment:
NODE_ENV: development
# 브라우저는 상대경로로 호출 → next dev server가 rewrites 로 컨테이너 내부 backend 로 프록시
# (절대 URL 박으면 호스트/IP 가 머신마다 달라서 다른 머신에서 접속 시 깨짐)
NEXT_PUBLIC_API_URL: /api
# 서버사이드(SSR/rewrites)에서 backend 호출용 — 컨테이너 네트워크 내부 이름
SERVER_API_URL: http://invyone-backend-spring:8081
NODE_OPTIONS: --max-old-space-size=8192
NEXT_TELEMETRY_DISABLED: "1"
WATCHPACK_POLLING: "true"
volumes:
- ../../frontend:/app
- /app/node_modules
- /app/.next
depends_on:
- backend-spring
networks:
- invyone-net
restart: unless-stopped
networks:
invyone-net:
name: invyone-net
driver: bridge