blob: 3b73f3c487594e3b764a5d01e427bdbd2e1bcea1 [file] [log] [blame]
# 阶段 1: builder - 构建应用 JAR 包 (跳过测试)
# 使用包含 Maven 和 JDK 的基础镜像
FROM maven:3.9.9-eclipse-temurin-24-alpine AS builder
# 设置工作目录
WORKDIR /app
# 复制 pom.xml 文件,以便 Maven 可以下载依赖
COPY pom.xml .
# 复制项目源代码,包括 main 和 test
# 这一步是为了让 Maven 在构建和下载依赖时能够解析所有模块
COPY src ./src
# 执行 Maven clean 和 dependency:go-offline
# clean: 清理 target 目录
# dependency:go-offline: 下载所有项目依赖到本地 Maven 仓库,供后续阶段使用
# -B: 非交互模式
# 这一步不执行实际的编译和测试,主要用于缓存依赖
RUN mvn clean dependency:go-offline -B
# 执行 Maven package 构建项目,生成 JAR 包
# -DskipTests: 跳过单元和集成测试
RUN mvn package -DskipTests
# 阶段 2: tester - 专用于运行和调试测试的运行时环境
# 基于与 builder 阶段相同的 Maven/JDK 基础镜像,确保测试所需的环境一致
FROM maven:3.9.9-eclipse-temurin-24-alpine AS tester
# 设置工作目录
WORKDIR /app
# 复制 pom.xml 和完整的 src 目录 (包含测试代码)
COPY pom.xml .
COPY src ./src
# 从 builder 阶段复制已缓存的 Maven 本地仓库
# 这样在 tester 阶段运行 Maven 时无需重新下载依赖
COPY --from=builder /root/.m2 /root/.m2
# 暴露调试端口 (可选,如果您需要远程调试测试过程)
# 您可以在 docker compose 中映射这个端口到主机
EXPOSE 5005
# 设置默认命令,使容器启动后保持运行
# 这样您可以方便地使用 docker exec 进入容器手动执行测试和调试命令
# 如果您希望容器启动后自动运行测试,可以修改此命令为 ["mvn", "test"]
CMD ["tail", "-f", "/dev/null"]
# 阶段 3: runner - 运行最终应用 JAR 包的精简运行时环境
# 使用轻量级的 OpenJDK JRE 镜像
FROM openjdk:17-jdk-slim-buster AS runner
# 设置工作目录
WORKDIR /app
# 从 builder 阶段复制构建好的应用 JAR 包
COPY --from=builder /app/target/demo-0.0.1-SNAPSHOT.jar app.jar
# 暴露 Spring Boot 应用的默认端口
EXPOSE 8080
# 启动 Spring Boot 应用
CMD ["java", "-jar", "app.jar"]