version: '3.8' services: trackeep-frontend: build: context: ./frontend dockerfile: Dockerfile ports: - "80:80" - "443:443" environment: - NODE_ENV=production depends_on: - trackeep-backend restart: unless-stopped networks: - trackeep-network trackeep-backend: build: context: ./backend dockerfile: Dockerfile ports: - "8080:8080" env_file: - .env.prod volumes: - ./data:/data - ./uploads:/app/uploads - ./logs:/app/logs restart: unless-stopped networks: - trackeep-network healthcheck: test: ["CMD", "wget", "--no-verbose", "--tries=1", "--spider", "http://localhost:8080/health"] interval: 30s timeout: 10s retries: 3 start_period: 40s postgres: image: postgres:15-alpine environment: POSTGRES_DB: ${POSTGRES_DB:-trackeep} POSTGRES_USER: ${POSTGRES_USER:-trackeep} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} POSTGRES_INITDB_ARGS: "--encoding=UTF-8 --lc-collate=C --lc-ctype=C" ports: - "5432:5432" volumes: - postgres_data:/var/lib/postgresql/data - ./backups:/backups restart: unless-stopped networks: - trackeep-network healthcheck: test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-trackeep} -d ${POSTGRES_DB:-trackeep}"] interval: 10s timeout: 5s retries: 5 redis: image: redis:7-alpine ports: - "6379:6379" volumes: - redis_data:/data restart: unless-stopped networks: - trackeep-network healthcheck: test: ["CMD", "redis-cli", "ping"] interval: 10s timeout: 3s retries: 3 # Backup service backup: image: postgres:15-alpine environment: POSTGRES_DB: ${POSTGRES_DB:-trackeep} POSTGRES_USER: ${POSTGRES_USER:-trackeep} POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} POSTGRES_HOST: postgres volumes: - ./backups:/backups - ./scripts/backup.sh:/backup.sh command: sh -c "chmod +x /backup.sh && crond -f" restart: unless-stopped networks: - trackeep-network depends_on: - postgres volumes: postgres_data: driver: local redis_data: driver: local networks: trackeep-network: driver: bridge