arm32v6/openjdk本镜像为openjdk官方镜像的arm32v6架构专用仓库。更多信息请参见官方镜像文档中的"除amd64外的架构?"和官方镜像FAQ中的"镜像源在Git中已更改,该怎么办?"。
本镜像已被官方弃用,建议所有用户尽快寻找并使用合适的替代方案。以下是一些官方镜像替代选项(按字母顺序排列,无优先级暗示):
amazoncorrettoeclipse-temurinibm-semeru-runtimesibmjavasapmachine更多信息请参见docker-library/openjdk#505。
2022年7月后,仅有早期访问版本(源自jdk.java.net)将继续接收更新,因为这些版本未被上述项目发布/支持。
维护者:
Docker社区
获取帮助:
Docker社区Slack、Server Fault、Unix & Linux或Stack Overflow
支持的标签及对应Dockerfile链接:
警告:本镜像在arm32v6架构上不受支持
提交问题的位置:
[***]
支持的架构:(更多信息)
amd64、arm64v8、windows-amd64
已发布镜像工件详情:
repo-info仓库的repos/openjdk/目录(历史记录)
(包含镜像元数据、传输大小等)
镜像更新:
official-images仓库的library/openjdk标签
official-images仓库的library/openjdk文件(历史记录)
本描述的来源:
docs仓库的openjdk/目录(历史记录)
OpenJDK(开放Java开发工具包)是Java平台标准版(Java SE)的免费开源实现。自版本7起,OpenJDK成为Java SE的官方参考实现。
***.org/wiki/OpenJDK
Java是Oracle和/或其关联公司的注册商标。
!logo
使用本镜像最直接的方式是将Java容器同时用作构建和运行环境。在Dockerfile中,可以编写如下内容来编译和运行项目:
dockerfileFROM arm32v6/openjdk:11 COPY . /usr/src/myapp WORKDIR /usr/src/myapp RUN javac Main.java CMD ["java", "Main"]
然后可以构建并运行Docker镜像:
console$ docker build -t my-java-app . $ docker run -it --rm --name my-running-app my-java-app
有时可能不适合在容器内运行应用。要在Docker实例内编译而非运行应用,可以执行如下命令:
console$ docker run --rm -v "$PWD":/usr/src/myapp -w /usr/src/myapp arm32v6/openjdk:11 javac Main.java
这会将当前目录作为卷挂载到容器中,将工作目录设置为该卷,并运行javac Main.java命令,该命令会让Java编译Main.java中的代码,并将Java类文件输出到Main.class。
JVM启动时会尝试检测可用CPU核心数和RAM,以调整内部参数(如生成的垃圾回收线程数)。当容器以有限的CPU/RAM运行时,JVM用于探测的标准系统API会返回主机范围的值。这可能导致旧版本JVM出现过高CPU使用率和内存分配错误。
在Linux容器中,OpenJDK 8及更高版本可以正确检测容器限制的CPU核心数和可用RAM。对于所有当前支持的OpenJDK版本,此功能默认启用。
在Windows Server(非Hyper-V)容器中,可用CPU核心数限制不起作用(被主机计算服务忽略)。要手动设置限制,JVM可以按如下方式启动:
console$ start /b /wait /affinity 0x3 path/to/java.exe ...
在此示例中,CPU亲和性十六进制掩码0x3会将JVM限制为2个CPU核心。
Windows Server容器支持RAM限制,但JVM目前无法检测。为防止过度内存分配,必须指定-XX:MaxRAM=...选项,其值不大于容器RAM限制。
某些shell(特别是Alpine Linux中包含的BusyBox /bin/sh)不支持名称中带句点的环境变量(技术上不符合POSIX标准),因此会剥离它们而不是传递(如Bash所做的那样)。如果应用需要此类环境变量,可以直接使用CMD ["java", ...](无shell),或(安装并)明确使用Bash而非/bin/sh。
查看本镜像中包含软件的许可证信息。
与所有Docker镜像一样,这些镜像可能还包含其他软件,这些软件可能受其他许可证约束(如基础发行版中的Bash等,以及主要软件的任何直接或间接依赖项)。
一些能够自动检测到的其他许可证信息可能位于repo-info仓库的openjdk/目录中。
对于任何预构建镜像的使用,镜像用户有责任确保对本镜像的任何使用都符合其中包含的所有软件的相关许可证。

manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务