# 构建阶段 FROM node:18-alpine as build-stage # 切换 Alpine 镜像源为阿里云 RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories # 设置环境变量 ARG NODE_ENV=production ENV NODE_ENV=${NODE_ENV} # 添加构建时间戳,用于破除缓存 ARG BUILD_TIMESTAMP=$(date +%s) ENV BUILD_TIMESTAMP=${BUILD_TIMESTAMP} # 输出构建环境信息 RUN echo "Building for environment: ${NODE_ENV}" RUN echo "Build timestamp: ${BUILD_TIMESTAMP}" # 安装 yarn RUN apk add --no-cache yarn # 设置 yarn 和 npm 镜像源为淘宝源 RUN yarn config set registry https://registry.npmmirror.com && \ npm config set registry https://registry.npmmirror.com # 设置工作目录 WORKDIR /app # 复制 package.json 和 yarn.lock COPY package.json yarn.lock* ./ # 安装依赖 RUN yarn install --frozen-lockfile # 复制项目文件 COPY . . # 创建或更新环境文件 RUN echo "NODE_ENV=${NODE_ENV}" > .env && \ echo "BUILD_TIMESTAMP=${BUILD_TIMESTAMP}" >> .env && \ if [ "$NODE_ENV" = "production" ]; then \ echo "VUE_APP_API_URL=https://api.beefast.co" >> .env; \ elif [ "$NODE_ENV" = "testing" ]; then \ echo "VUE_APP_API_URL=https://api-dev.beefast.co" >> .env; \ else \ echo "VUE_APP_API_URL=http://localhost:8000" >> .env; \ fi && \ cat .env # 根据环境变量选择构建命令 RUN if [ "$NODE_ENV" = "production" ]; then \ echo "Running production build" && \ yarn build:prod; \ elif [ "$NODE_ENV" = "testing" ]; then \ echo "Running testing build" && \ yarn build:test; \ else \ echo "Running development build" && \ yarn build:dev; \ fi # 生产阶段 FROM nginx:stable-alpine as production-stage # 切换 Alpine 镜像源为阿里云 RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories # 复制构建结果到Nginx目录 COPY --from=build-stage /app/dist /usr/share/nginx/html # 复制Nginx配置文件 COPY nginx.conf /etc/nginx/conf.d/default.conf # 添加构建信息文件,用于验证部署 RUN echo "Build completed at: $(date)" > /usr/share/nginx/html/build-info.txt # 暴露80端口 EXPOSE 80 # 启动Nginx CMD ["nginx", "-g", "daemon off;"]