yyyang | 3bd72f0 | 2025-06-03 16:35:11 +0800 | [diff] [blame] | 1 | # 构建阶段 |
| 2 | FROM node:18-alpine as build |
| 3 | |
| 4 | # 设置工作目录 |
| 5 | WORKDIR /app |
| 6 | |
| 7 | # 设置 npm 镜像源(使用淘宝镜像加速 npm 包下载) |
| 8 | RUN npm config set registry https://registry.npmmirror.com |
| 9 | |
| 10 | # 复制 package.json 和 package-lock.json |
| 11 | COPY package*.json ./ |
| 12 | |
| 13 | # 安装依赖 |
| 14 | RUN npm install |
| 15 | |
| 16 | # 复制源代码 |
| 17 | COPY . . |
| 18 | |
| 19 | # 清理之前的构建产物 |
| 20 | RUN rm -rf dist |
| 21 | |
| 22 | # 构建应用 |
| 23 | RUN npm run build |
| 24 | |
| 25 | # 验证构建产物 |
| 26 | RUN ls -la dist && \ |
| 27 | ls -la dist/assets |
| 28 | |
| 29 | # 生产阶段 |
yyyang | 3339646 | 2025-06-03 17:36:35 +0800 | [diff] [blame^] | 30 | FROM nginx:stable |
yyyang | 3bd72f0 | 2025-06-03 16:35:11 +0800 | [diff] [blame] | 31 | |
| 32 | # 设置时区 |
| 33 | ENV TZ=Asia/Shanghai |
yyyang | 3339646 | 2025-06-03 17:36:35 +0800 | [diff] [blame^] | 34 | RUN apt-get update && \ |
| 35 | apt-get install -y tzdata && \ |
| 36 | ln -fs /usr/share/zoneinfo/$TZ /etc/localtime && \ |
| 37 | echo $TZ > /etc/timezone && \ |
| 38 | apt-get clean && \ |
| 39 | rm -rf /var/lib/apt/lists/* |
yyyang | 3bd72f0 | 2025-06-03 16:35:11 +0800 | [diff] [blame] | 40 | |
| 41 | # 清理 nginx 目录 |
| 42 | RUN rm -rf /usr/share/nginx/html/* |
| 43 | |
| 44 | # 直接复制本地构建的文件 |
| 45 | COPY dist/ /usr/share/nginx/html/ |
| 46 | |
| 47 | # 验证文件是否正确复制 |
| 48 | RUN ls -la /usr/share/nginx/html && \ |
| 49 | ls -la /usr/share/nginx/html/assets |
| 50 | |
| 51 | # 复制 Nginx 配置文件 |
| 52 | COPY nginx.conf /etc/nginx/conf.d/default.conf |
| 53 | |
| 54 | # 暴露端口 |
| 55 | EXPOSE 80 |
| 56 | |
| 57 | # 启动 Nginx |
| 58 | CMD ["nginx", "-g", "daemon off;"] |