Docker 构建Java 应用程序包

本文涉及的产品
对象存储 OSS,标准 - 本地冗余存储 20GB 3个月
对象存储 OSS,内容安全 1000 次 1年
对象存储OSS,敏感数据保护2.0 200GB 1年
简介: 生产经验
作者: 张首富
时间: 2021-02-01
微信: y18163201

前言

目前我们公司使用的基本上都是java开发的后端,本文详细的介绍了公司java程序docker 包构建的演变过程,这里面不对java包本身的构建做过多的赘述。

docker 镜像的演变过程

最初的时候我们只想着给java包怎么放到docker 镜像中,我们使用了如下的Dockerfile

FROM openjdk:8u212-jre-alpine
ENV TZ="Asia/Shanghai"
ENV JVM="-XX:MetaspaceSize=256m -XX:MaxMetaspaceSize=512m -Xms1024m -Xmx2048m -Xmn512m -Xss512k -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC"

RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime ; \
    echo $TZ > /etc/timezone  ; \
    mkdir -p /var/upload_tmp ;\
    mkdir -p /home/guiyu-v2/config ; \
    mkdir -p /home/guiyu-v2/jar ;  \
    mkdir -p /home/guiyu-v2/jar/logxml ;\
    mkdir -p /home/temp_download/oss


CMD ["sh","-c","java `echo $JVM` -Djava.io.tmpdir=/var/upload_tmp -Dfile.encoding=utf-8 -Dspring.config.location=/home/guiyu-v2/config/oss.yml -Dlogging.config=/home/guiyu-v2/jar/logxml/log-oss.xml -jar /home/guiyu-v2/jar/guiyu-oss-web-2.0-SNAPSHOT.jar"]

COPY ./guiyu-oss-web/src/main/resources/application.yml /home/guiyu-v2/config/oss.yml
COPY ./guiyu-oss-web/target/guiyu-oss-web-2.0-SNAPSHOT.jar /home/guiyu-v2/jar/
COPY ./guiyu-oss-web/src/main/resources/logback.xml /home/guiyu-v2/jar/logxml/log-oss.xml

使用上面的Dockerfile 显着运维人员太没有技术水平了,然后吧启动参数变成可变的变量,于是乎演变成下面

FROM openjdk:8u212-jre-alpine
ENV TZ="Asia/Shanghai"
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime ; \
    echo $TZ > /etc/timezone  ; \
      mkdir -p /var/upload_tmp ;\
    mkdir -p /home/work/ ; \
    mkdir -p /home/work/ ;  \
    mkdir -p //home/work/ ;\
    mkdir -p /home/temp_download/oss ;\
    sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories
    
ENV JVM_OPTS -server -Xms1g -Xmx1g -XX:+UseG1GC
ENV JAVA_OPTS -Dfile.encoding=UTF-8 -Djava.security.egd=file:/dev/urandom  -Dspring.profiles.active=prod -Dlogging.config=/home/work/logback-spring.xml
ENV JAVA_AGENT=
ENV APP_NAME=guiyu-oss-web-2.0-SNAPSHOT.jar

CMD  java ${JVM_OPTS} ${JAVA_OPTS} ${JAVA_AGENT} -jar ${APP_NAME}

COPY ./guiyu-oss-web/src/main/resources/application.yml /home/work/application.yml
COPY ./guiyu-oss-web/target/guiyu-oss-web-2.0-SNAPSHOT.jar /home/work/
COPY ./guiyu-oss-web/src/main/resources/logback.xml /home/work/logback-spring.xml

发展到这个地步的时候我们启动就只需要改 JVM_OPTSJAVA_OPTS 参数即可,稍微有点人性化了,但是好景不长,线上出了一点问题,需要通过jvm分析工具来看看那个地方出问题了,我们采用上面这种方式构建的docker镜像无法使用jvm分析工具。

因为上面这种方式构建的Docker镜像里面所有的java进程都是 PID 为1,jvm分析PId 为1 的有点问题,而且好多服务并不能处理系统发送的kill 指令,这所是我不能容忍的,所以就进化成了如下样子,(docker 不能优雅的stop 请查看我这篇文章https://www.cnblogs.com/shoufu/p/12978843.html)

然后给Docker 添加一个init 进程放在主进程

FROM openjdk:8u212-jre-alpine
ENV TZ="Asia/Shanghai"
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime ; \
    echo $TZ > /etc/timezone  ; \
      mkdir -p /var/upload_tmp ;\
    mkdir -p /home/work/ ; \
    mkdir -p /home/work/ ;  \
    mkdir -p //home/work/ ;\
    mkdir -p /home/temp_download/oss ;\
    sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories ;\
    RUN apk add --no-cache tini

    
ENV JVM_OPTS -server -Xms1g -Xmx1g -XX:+UseG1GC
ENV JAVA_OPTS -Dfile.encoding=UTF-8 -Djava.security.egd=file:/dev/urandom  -Dspring.profiles.active=prod -Dlogging.config=/home/work/logback-spring.xml
ENV JAVA_AGENT=
ENV APP_NAME=guiyu-oss-web-2.0-SNAPSHOT.jar

ENTRYPOINT ["/sbin/tini", "--"]
CMD  java ${JVM_OPTS} ${JAVA_OPTS} ${JAVA_AGENT} -jar ${APP_NAME}

COPY ./guiyu-oss-web/src/main/resources/application.yml /home/work/application.yml
COPY ./guiyu-oss-web/target/guiyu-oss-web-2.0-SNAPSHOT.jar /home/work/
COPY ./guiyu-oss-web/src/main/resources/logback.xml /home/work/logback-spring.xml

到这个时候为止,大部分问题都已经解决,但是进去到docker 容器里面发现没有 jmap等指令,需要通过如下命令去安装即可

apk add openjdk8 

本着docker 镜像最小原则,就没有把它安装到所有的docker镜像中去。

到此公司的java包docker 镜像构建完毕

相关实践学习
通义万相文本绘图与人像美化
本解决方案展示了如何利用自研的通义万相AIGC技术在Web服务中实现先进的图像生成。
目录
相关文章
|
2月前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
247 8
|
2月前
|
机器学习/深度学习 人工智能 自然语言处理
Java与生成式AI:构建内容生成与创意辅助系统
生成式AI正在重塑内容创作、软件开发和创意设计的方式。本文深入探讨如何在Java生态中构建支持文本、图像、代码等多种生成任务的创意辅助系统。我们将完整展示集成大型生成模型(如GPT、Stable Diffusion)、处理生成任务队列、优化生成结果以及构建企业级生成式AI应用的全流程,为Java开发者提供构建下一代创意辅助系统的完整技术方案。
199 10
|
2月前
|
人工智能 算法 Java
Java与AI驱动区块链:构建智能合约与去中心化AI应用
区块链技术和人工智能的融合正在开创去中心化智能应用的新纪元。本文深入探讨如何使用Java构建AI驱动的区块链应用,涵盖智能合约开发、去中心化AI模型训练与推理、数据隐私保护以及通证经济激励等核心主题。我们将完整展示从区块链基础集成、智能合约编写、AI模型上链到去中心化应用(DApp)开发的全流程,为构建下一代可信、透明的智能去中心化系统提供完整技术方案。
250 3
|
2月前
|
机器学习/深度学习 人工智能 监控
Java与AI模型部署:构建企业级模型服务与生命周期管理平台
随着企业AI模型数量的快速增长,模型部署与生命周期管理成为确保AI应用稳定运行的关键。本文深入探讨如何使用Java生态构建一个企业级的模型服务平台,实现模型的版本控制、A/B测试、灰度发布、监控与回滚。通过集成Spring Boot、Kubernetes、MLflow和监控工具,我们将展示如何构建一个高可用、可扩展的模型服务架构,为大规模AI应用提供坚实的运维基础。
239 0
|
2月前
|
人工智能 Java 物联网
Java与边缘AI:构建离线智能的物联网与移动应用
随着边缘计算和终端设备算力的飞速发展,AI推理正从云端向边缘端迁移。本文深入探讨如何在资源受限的边缘设备上使用Java构建离线智能应用,涵盖从模型优化、推理加速到资源管理的全流程。我们将完整展示在Android设备、嵌入式系统和IoT网关中部署轻量级AI模型的技术方案,为构建真正实时、隐私安全的边缘智能应用提供完整实践指南。
325 3
|
2月前
|
消息中间件 缓存 Java
Spring框架优化:提高Java应用的性能与适应性
以上方法均旨在综合考虑Java Spring 应该程序设计原则, 数据库交互, 编码实践和系统架构布局等多角度因素, 旨在达到高效稳定运转目标同时也易于未来扩展.
127 8
|
2月前
|
人工智能 监控 Java
Java与AI智能体:构建自主决策与工具调用的智能系统
随着AI智能体技术的快速发展,构建能够自主理解任务、制定计划并执行复杂操作的智能系统已成为新的技术前沿。本文深入探讨如何在Java生态中构建具备工具调用、记忆管理和自主决策能力的AI智能体系统。我们将完整展示从智能体架构设计、工具生态系统、记忆机制到多智能体协作的全流程,为Java开发者提供构建下一代自主智能系统的完整技术方案。
398 4
|
SQL 缓存 Dubbo
探索 Java ServiceLoader、Dubbo ExtensionLoader:构建灵活可扩展的应用程序的利器(下)
探索 Java ServiceLoader、Dubbo ExtensionLoader:构建灵活可扩展的应用程序的利器(下)
255 0
|
Dubbo Java 关系型数据库
探索 Java ServiceLoader、Dubbo ExtensionLoader:构建灵活可扩展的应用程序的利器(上)
探索 Java ServiceLoader、Dubbo ExtensionLoader:构建灵活可扩展的应用程序的利器
256 0