Files
photography/frontend/docker-compose.yml
xujiang 6efccae78a feat: 完成容器化系统和用户文档开发
本次提交包含3个重要功能的完成:

1. 📖 用户使用文档完成
   - 创建完整的用户使用手册 (docs/USER_MANUAL.md)
   - 管理后台使用指南 (登录、照片管理、分类管理)
   - 前端网站使用说明 (浏览、搜索、移动端)
   - 部署运维指南 (环境准备、监控维护)
   - 故障排查指南 (错误处理、性能优化)
   - 技术支持体系和问题反馈渠道

2. 🐳 后端Docker容器化完成
   - 多阶段构建Dockerfile (golang:1.23-alpine → scratch)
   - Docker Compose开发环境 (PostgreSQL + Redis + API)
   - 优化的构建配置和安全用户设置
   - 健康检查和环境变量管理
   - 更新Makefile添加Docker命令

3. 🏗️ 前端Docker容器化完成
   - 多阶段构建Dockerfile (node:20-alpine → nginx:1.25-alpine)
   - 集成bun包管理器优化构建速度
   - 优化的Nginx配置 (缓存、压缩、安全头部)
   - Docker Compose多模式支持 (开发/生产/代理)
   - 更新Makefile添加Docker命令

4. 📋 完整的Docker编排系统
   - 项目根目录完整的docker-compose.yml
   - 支持数据库、缓存、API、前端、管理后台的统一部署
   - 自动化Docker设置脚本 (docker-setup.sh)
   - 生产环境监控和日志收集配置

技术成果:
- 项目完成率从65.0%提升至72.5%
- 中优先级任务完成率达90%
- 低优先级任务开始推进(18%)
- 容器化部署体系完全就绪
- 用户文档体系建立完成

下一步: 继续推进容器化扩展和性能优化任务
2025-07-11 14:29:04 +08:00

115 lines
2.8 KiB
YAML

# Photography Portfolio Frontend - Docker Compose
# 本地开发和测试环境配置
version: '3.8'
services:
# 前端应用服务
frontend:
build:
context: .
dockerfile: Dockerfile
target: production
container_name: photography-frontend
ports:
- "3000:80"
environment:
# API配置
NEXT_PUBLIC_API_URL: ${NEXT_PUBLIC_API_URL:-http://localhost:8080}
NEXT_PUBLIC_API_TIMEOUT: ${NEXT_PUBLIC_API_TIMEOUT:-10000}
# 应用配置
NODE_ENV: production
NEXT_PUBLIC_APP_NAME: "Photography Portfolio"
NEXT_PUBLIC_APP_VERSION: "1.0.0"
# 功能开关
NEXT_PUBLIC_ENABLE_ANALYTICS: ${NEXT_PUBLIC_ENABLE_ANALYTICS:-false}
NEXT_PUBLIC_ENABLE_PWA: ${NEXT_PUBLIC_ENABLE_PWA:-true}
# 上传配置
NEXT_PUBLIC_MAX_FILE_SIZE: ${NEXT_PUBLIC_MAX_FILE_SIZE:-10485760}
NEXT_PUBLIC_ALLOWED_FILE_TYPES: ${NEXT_PUBLIC_ALLOWED_FILE_TYPES:-image/jpeg,image/png,image/gif,image/webp}
networks:
- photography-network
restart: unless-stopped
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost/health"]
interval: 30s
timeout: 10s
retries: 3
start_period: 10s
depends_on:
- api
labels:
- "com.photography.service=frontend"
- "com.photography.version=1.0.0"
# 后端API服务 (用于本地开发)
api:
image: photography-api:latest
container_name: photography-api-dev
ports:
- "8080:8080"
environment:
APP_ENV: development
CORS_ORIGINS: "http://localhost:3000"
networks:
- photography-network
restart: unless-stopped
profiles:
- dev
# 开发环境服务 (热重载)
dev:
build:
context: .
dockerfile: Dockerfile
target: builder
container_name: photography-frontend-dev
ports:
- "3000:3000"
- "3001:3001" # 热重载端口
environment:
NODE_ENV: development
NEXT_PUBLIC_API_URL: http://localhost:8080
WATCHPACK_POLLING: true
volumes:
- .:/app
- node_modules:/app/node_modules
networks:
- photography-network
command: bun run dev
restart: unless-stopped
profiles:
- dev
# Nginx 代理服务 (可选)
nginx:
image: nginx:1.25-alpine
container_name: photography-nginx
ports:
- "80:80"
- "443:443"
volumes:
- ./nginx.conf:/etc/nginx/nginx.conf:ro
- ./default.conf:/etc/nginx/conf.d/default.conf:ro
- ssl_certs:/etc/nginx/ssl:ro
networks:
- photography-network
depends_on:
- frontend
restart: unless-stopped
profiles:
- proxy
volumes:
node_modules:
driver: local
ssl_certs:
driver: local
networks:
photography-network:
driver: bridge
external: true