DockerFile实战

背景

在上一篇文章中,我们对DockerFile有了一个较为深刻的认识,那么这篇文章,我将会向你展示如何自定义一个镜像并且在docker上运行。

一、基础指令

指令 技术说明 生产环境最佳实践 典型错误示例
FROM - 必须作为Dockerfile第一条指令 - 推荐使用官方镜像的LTS版本 FROM eclipse-temurin:17-jre-jammy FROM ubuntu:latest
ENV - 支持多变量定义:ENV A=1 B=2 - 会被后续RUN/CMD等指令继承 ENV JAVA_OPTS="-Xms512m -Xmx1024m" ENV PATH=$PATH:/tmp
COPY - 支持通配符:COPY *.jar /app/ - 会保留文件元数据 COPY --chown=1000:1000 . /app COPY /opt/xxx /app
RUN - 多个命令用&&连接 - 用\换行提高可读性 RUN apt update && apt install -y \ curl && rm -rf /var/lib/apt/lists/* RUN cd /app && tar xf pkg.tar
EXPOSE - 只是声明而非实际开放端口 - 需与docker run -p配合 EXPOSE 8080/tcp 8443/udp EXPOSE 8080-8090
ENTRYPOINT - 容器的主进程 - 建议用JSON数组格式 ENTRYPOINT ["java", "-jar", "app.jar"] ENTRYPOINT java -jar app.jar
java 复制代码
#1、准备Linux运行环境(推荐使用轻量级基础镜像)
FROM eclipse-temurin:17-jre-alpine

#2、安装JRE并配置环境变量(基础镜像已包含,此处为扩展配置)
ENV JAVA_OPTS="-Xms512m -Xmx1024m"
ENV TZ=Asia/Shanghai

#3、拷贝Jar包(使用分层构建优化)
COPY target/*.jar /app/application.jar

#4、编写运行脚本(使用ENTRYPOINT+CMD组合)
ENTRYPOINT ["sh", "-c", "java ${JAVA_OPTS} -jar /app/application.jar"]
EXPOSE 8888

二、分步骤技术解析

① 基础镜像选择

  • 推荐方案​:

    java 复制代码
    FROM eclipse-temurin:17-jre-alpine
    • openjdk镜像更小(Alpine版约85MB)
    • 已包含完整的JRE环境
  • 替代方案​:

    java 复制代码
    FROM amazoncorretto:17  # 亚马逊优化版

② 环境配置增强

java 复制代码
# 内存配置(根据应用需求调整)
ENV JAVA_OPTS="-Xms512m -Xmx1024m -XX:+UseG1GC"

# 时区设置
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone

③ 应用部署优化

  • 分层构建技巧

    java 复制代码
    COPY --chown=1000:1000 target/*.jar /app/  # 指定非root用户
  • 版本控制

    java 复制代码
    ARG JAR_FILE=target/*.jar
    COPY ${JAR_FILE} /app/application.jar

④ 启动脚本进阶

java 复制代码
# 健康检查(K8s就绪探针)
HEALTHCHECK --interval=30s --timeout=3s \
  CMD curl -f http://localhost:8888/actuator/health || exit 1

# 允许传递启动参数
CMD ["--spring.profiles.active=prod"]

三、构建与运行命令

  1. 构建镜像​:

    java 复制代码
    docker build -t java-app:v1 .
  2. 运行容器​:

    java 复制代码
    docker run -d -p 8860:8888 \
      -e JAVA_OPTS="-Xmx2048m" \
      java-app:v1

容器创建成功:

四、生产环境建议

  1. 安全加固​:

    java 复制代码
    USER 1000  # 使用非root用户
    RUN addgroup -S appgroup && adduser -S appuser -G appgroup
  2. 多阶段构建​(如需包含JDK编译):

    java 复制代码
    FROM eclipse-temurin:17-jdk as builder
    WORKDIR /build
    COPY . .
    RUN ./gradlew bootJar
    
    FROM eclipse-temurin:17-jre-alpine
    COPY --from=builder /build/build/libs/*.jar /app.jar
  3. 镜像扫描​:

    java 复制代码
    docker scan java-app:v1

五、常见问题排查

问题现象 解决方案
容器启动立即退出 docker logs <container> 查看JVM错误
内存溢出(OOM) 调整-Xmx参数并检查内存泄漏
时区不正确 确认TZ环境变量已正确设置
应用性能低下 考虑使用-XX:+UseContainerSupport
相关推荐
Linux编程用C21 小时前
Docker+Vscode搭建(本地/远程)开发环境
vscode·后端·docker
林疏safe1 天前
灯塔部署云服务器docker 部署方式,以及忘记密码如何查找
运维·服务器·docker
木卫二号Coding1 天前
affine+docker+postgresql+备份数据库
数据库·docker·容器
檀越剑指大厂1 天前
查看 Docker 镜像详情的几种常用方法
docker·容器·eureka
java_logo1 天前
Webtop Docker 容器化部署指南:基于浏览器的Linux桌面环境
linux·docker·容器·webtop·webtop部署教程·docker部署webtop·linux桌面
技术小李...1 天前
docker下mysql更改密码后WordPress提示无法连接数据库问题
运维·docker·容器
JPX-NO1 天前
windows下编程IDE使用docker搭建的rust开发环境(Linux)
ide·windows·docker·rust
快乐就去敲代码@!1 天前
Boot Cache Star ⭐(高性能两级缓存系统)
spring boot·redis·后端·缓存·docker·压力测试
爱学大树锯1 天前
在Docker环境中安装RabbitMQ延迟消息插件实战记录
docker·容器·rabbitmq
一周困⁸天.1 天前
K8s -蓝绿发布与金丝雀发布
docker·容器·kubernetes