2025-06-23 16:50:28 +08:00
|
|
|
|
# 使用多阶段构建优化镜像大小
|
2025-06-23 22:36:43 +08:00
|
|
|
|
FROM amazoncorretto:17-alpine-jdk as builder
|
2025-06-23 16:50:28 +08:00
|
|
|
|
|
|
|
|
|
# 设置工作目录
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
|
|
|
# 复制Maven配置文件
|
|
|
|
|
COPY pom.xml .
|
|
|
|
|
COPY .mvn .mvn
|
|
|
|
|
COPY mvnw .
|
|
|
|
|
|
2025-06-23 23:17:37 +08:00
|
|
|
|
# 给mvnw脚本添加执行权限
|
|
|
|
|
RUN chmod +x ./mvnw
|
|
|
|
|
|
2025-06-23 16:50:28 +08:00
|
|
|
|
# 下载依赖(利用Docker缓存层)
|
|
|
|
|
RUN ./mvnw dependency:go-offline -B
|
|
|
|
|
|
|
|
|
|
# 复制源代码
|
|
|
|
|
COPY src ./src
|
|
|
|
|
|
|
|
|
|
# 构建应用
|
|
|
|
|
RUN ./mvnw clean package -DskipTests
|
|
|
|
|
|
2025-06-23 22:36:43 +08:00
|
|
|
|
# 运行时镜像 - 使用更小的Alpine镜像
|
|
|
|
|
FROM amazoncorretto:17-alpine
|
|
|
|
|
|
|
|
|
|
# 安装curl用于健康检查
|
|
|
|
|
RUN apk add --no-cache curl
|
2025-06-23 16:50:28 +08:00
|
|
|
|
|
|
|
|
|
# 设置时区
|
|
|
|
|
ENV TZ=Asia/Shanghai
|
2025-06-23 22:36:43 +08:00
|
|
|
|
RUN apk add --no-cache tzdata && \
|
|
|
|
|
ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
|
2025-06-23 16:50:28 +08:00
|
|
|
|
|
|
|
|
|
# 创建非root用户
|
2025-06-23 22:36:43 +08:00
|
|
|
|
RUN addgroup -g 1000 spring && adduser -u 1000 -G spring -s /bin/sh -D spring
|
2025-06-23 16:50:28 +08:00
|
|
|
|
|
|
|
|
|
# 创建应用目录
|
|
|
|
|
WORKDIR /app
|
|
|
|
|
|
|
|
|
|
# 从构建阶段复制jar文件
|
|
|
|
|
COPY --from=builder /app/target/*.jar app.jar
|
|
|
|
|
|
|
|
|
|
# 创建日志目录
|
|
|
|
|
RUN mkdir -p /app/logs && chown -R spring:spring /app
|
|
|
|
|
|
|
|
|
|
# 切换到非root用户
|
|
|
|
|
USER spring
|
|
|
|
|
|
|
|
|
|
# 暴露端口
|
|
|
|
|
EXPOSE 8080
|
|
|
|
|
|
|
|
|
|
# 健康检查
|
|
|
|
|
HEALTHCHECK --interval=30s --timeout=3s --start-period=60s --retries=3 \
|
|
|
|
|
CMD curl -f http://localhost:8080/api/health || exit 1
|
|
|
|
|
|
|
|
|
|
# JVM调优参数
|
|
|
|
|
ENV JAVA_OPTS="-server -Xms256m -Xmx512m -XX:+UseG1GC -XX:+UseContainerSupport -XX:MaxRAMPercentage=75.0"
|
|
|
|
|
|
|
|
|
|
# 启动应用
|
|
|
|
|
ENTRYPOINT ["sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar app.jar"]
|