Docker映像-类型。苗条vs苗条伸展vs伸展vs高山

mai*_*ash 61 docker dockerfile

我希望拿起一个docker映像来构建一个Java应用程序,并查看可用的OpenJDK映像的变体。我在这里查看https://github.com/docker-library/openjdk/tree/master/8/jdk,看到阿尔卑斯山,细长的窗户。这些之间有什么区别,每个变体都有什么区别?

acd*_*ior 58

每个Docker库文档(下面的引号和链接)为摘要:

  • openjdk:<version>

实际图像。如果不确定,请使用它。

  • openjdk:<version>-busteropenjdk:<version>-stretchopenjdk:<version>-jessie

busterjessie或者stretchDebian发行版的套件代码名称,并指示映像所基于的发行版

  • openjdk:<version>-alpine

同样,该映像基于Alpine Linux,因此是非常小的基础映像。如果您需要图像尺寸尽可能小,建议您这样做。需要注意的是,它使用了一些不寻常的库,但是对于大多数软件来说应该不是问题。如有疑问,请查看下面的官方文档。

  • openjdk:<version>(从12开始),openjdk:<version>-oracle以及openjdk:<version>-oraclelinux7

openjdk:12默认映像以及-oracle-oraclelinux7变体开始,均基于官方Oracle Linux 7映像。默认映像中的OpenJDK二进制文件以及-oracle-oraclelinux7变体由Oracle构建,并来自OpenJDK社区

  • openjdk:<version>-slim

该映像仅包含运行Java所需的最少软件包(例如,缺少许多与UI相关的Java库)。除非你是在一个环境中工作,其中openjdk图像将被部署,你有空间的限制,默认的图像,建议在这一个。

  • openjdk:<version>-windowsservercore

该映像基于Windows Server Core(microsoft/windowsservercore



完整文档(版本如下所示最新版本位于此处):

图像变体

openjdk图像有许多种,每一个设计用于特定的使用情况。

openjdk:<version>

这是事实上的图像。如果不确定自己的需求,则可能要使用这一需求。它既可以用作一次性容器(安装源代码并启动容器以启动应用程序),也可以用作构建其他图像的基础。

其中一些标签的名称可能像jessie或在其中延伸。这些是Debian发行版的套件代码名称 ,指示该映像所基于的发行版。

openjdk:<version>-alpine

该图像是基于流行的高山Linux项目,可用alpine官方图片。Alpine Linux比大多数分发基础映像(〜5MB)小得多,因此通常导致更苗条的映像。

当希望最终图像尺寸尽可能小时,强烈建议使用此变体。需要注意的主要警告是,它确实使用了musl libc而不是glibc和friends,因此某些软件可能会遇到问题,具体取决于其libc要求的深度。但是,大多数软件对此没有问题,因此,此变体通常是非常安全的选择。请参阅此Hacker News评论线程,以获取有关可能出现的问题的更多讨论以及使用基于Alpine的图像的一些优缺点的比较。

为了最大程度地减小图像尺寸,通常不会在基于Alpine的图像中包含其他相关工具(例如gitbash)。以该映像为基础,在自己的Dockerfile中添加所需的内容(如果不熟悉,请参阅alpine映像描述以获取有关如何安装软件包的示例)。

openjdk:<version>-windowsservercore

该映像基于Windows Server Core(microsoft/windowsservercore。因此,它仅在该映像可以运行的位置工作,例如Windows 10专业版/企业版(周年纪念版)或Windows Server 2016。

有关如何在Windows上运行Docker的信息,请参阅Microsoft提供的相关“快速入门”指南:

openjdk:<version>-slim

该映像安装了-headlessOpenJDK 的软件包,因此缺少许多与UI相关的Java库以及默认标记中包含的一些常见软件包。它仅包含运行Java所需的最少软件包。除非你是在一个环境中工作,其中 openjdk图像将被部署,你有空间的限制,我们强烈建议您使用此库的默认图像。


Gha*_*ghi 7

选择适合您需求的基础 docker 镜像,请记住镜像大小也是一个重要方面

镜像可以被认为是一组关于如何创建容器的指令。在 Docker 中,一个镜像可以继承(或基于)另一个镜像,在基本镜像之上添加额外的指令。每个图像由多个层组成,这些层实际上是不可变的。

请阅读打造完美的 Java Docker 构建流程一文。

Docker镜像的大小实际上非常重要。尺寸会影响:

  • 网络延迟:需要通过网络传输 Docker 镜像
  • 存储:需要将所有这些位存储在某处
  • 服务可用性和弹性:当使用 Docker 调度程序时,如 Kubernetes、Swarm、Nomad、DC/OS 或其他(调度程序可以在主机之间移动容器)
  • 安全性:我的意思是,您真的需要为您的 Java 应用程序提供包含所有 CVE 漏洞的 libpng 包吗?
  • 开发敏捷性:小型 Docker 镜像 == 更快的构建时间和更快的部署


要运行 java 应用程序,您至少需要 JRE。例如,对于 Spring 项目,您的图像可以基于slim Alpine Linux with OpenJDK JRE

#simple dockerFile for java app:

#here we are using Base Alpine Linux based image with OpenJDK JRE only
#For Java 8, try this
FROM openjdk:8-jre-alpine

#For Java 11, try this
#FROM adoptopenjdk/openjdk11:alpine-jre

#copy application WAR/JAR (with libraries inside)
COPY target/spring-boot-*.war/jar yourName.war/jar
# specify default command
CMD ["/usr/bin/java", "-jar", "/yourName.war/jar"]
Run Code Online (Sandbox Code Playgroud)

您还可以用来docker history yourImageName查看构成图像的所有图层(及其大小)。