https://github.com/NoEnv/docker-openjdk/actions/workflows/build.yml/badge.svg](https://github.com/NoEnv/docker-openjdk/actions/workflows/build.yml) https://github.com/NoEnv/docker-openjdk/actions/workflows/server.yml/badge.svg](https://github.com/NoEnv/docker-openjdk/actions/workflows/server.yml)
noenv/openjdk 是由 NoEnv 维护的 OpenJDK 官方实现的 Docker 镜像,旨在为 Java 应用程序提供轻量、可靠且标准化的运行环境。该镜像基于 OpenJDK 官方源码构建,集成了必要的运行时依赖,适用于各类 Java 应用(包括控制台程序、Web 应用、微服务等)的容器化部署。
docker run、docker-compose 等)从 Docker Hub 拉取最新版本(默认标签为 latest,对应最新 LTS 版本):
bashdocker pull noenv/openjdk:latest
如需指定 Java 版本,可使用版本标签(如 Java 17):
bashdocker pull noenv/openjdk:17
查看所有可用标签:https://hub.docker.com/r/noenv/openjdk/tags
运行 Java 控制台应用
将本地 JAR 文件挂载到容器中并执行:
bashdocker run -it --rm \ -v $(pwd)/my-app.jar:/app/app.jar \ noenv/openjdk:17 \ java -jar /app/app.jar
运行 Spring Boot 应用
通过环境变量传递 JVM 参数(如内存配置):
bashdocker run -d --name spring-app \ -p 8080:8080 \ -v $(pwd)/app.jar:/app.jar \ -e JAVA_OPTS="-Xms512m -Xmx1g -XX:+UseContainerSupport" \ noenv/openjdk:17 \ java $JAVA_OPTS -jar /app.jar
创建 docker-compose.yml 文件,定义服务配置:
yamlversion: '3.8' services: java-app: image: noenv/openjdk:17 container_name: java-app restart: always ports: - "8080:8080" volumes: - ./app:/app # 挂载应用代码或配置文件 - app-logs:/var/log/app # 持久化日志 environment: - JAVA_OPTS="-Xmx1g -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/var/log/app/dump.hprof" - TZ=Asia/Shanghai # 设置时区 working_dir: /app command: java $JAVA_OPTS -jar app.jar volumes: app-logs: # 声明持久化卷
启动服务:
bashdocker-compose up -d
| 环境变量 | 描述 | 默认值 | 示例 |
|---|---|---|---|
JAVA_HOME | Java 安装路径(只读,镜像内置) | /usr/lib/jvm/default-jvm | - |
JAVA_OPTS | 自定义 JVM 参数 | 空 | -Xms256m -Xmx512m -Duser.timezone=UTC |
WORKDIR | 容器工作目录 | / | /app |
USER | 运行应用的用户(用户名或 UID) | root | 1000(非 root 用户 UID) |
TZ | 系统时区 | UTC | Asia/Shanghai |
非 Root 用户运行
为增强安全性,指定非 root 用户运行应用(需确保挂载目录权限):
bashdocker run -it --rm \ -v $(pwd)/app.jar:/app.jar \ -u 1000:1000 \ # UID:GID,需与宿主机目录权限匹配 noenv/openjdk:17 \ java -jar /app.jar
自定义 JVM 日志输出
将 JVM 日志重定向到文件或标准输出:
bashdocker run -d \ -e JAVA_OPTS="-XX:+PrintGCDetails -Xlog:gc*:file=/var/log/gc.log:time" \ -v $(pwd)/logs:/var/log \ noenv/openjdk:17 \ java $JAVA_OPTS -jar /app.jar
noenv/openjdk:8)。docker volume 或宿主机挂载持久化,避免容器删除后数据丢失。--memory、--cpus 参数限制容器资源,避免 JVM 内存溢出。docker scan 定期检查镜像漏洞。https://github.com/NoEnv/docker-openjdk/actions/workflows/build.yml/badge.svg](https://github.com/NoEnv/docker-openjdk/actions/workflows/build.yml) https://github.com/NoEnv/docker-openjdk/actions/workflows/server.yml/badge.svg](https://github.com/NoEnv/docker-openjdk/actions/workflows/server.yml)
noenv/openjdk 是由 NoEnv 维护的 OpenJDK 官方实现 Docker 镜像,旨在为 Java 应用提供轻量、可靠的标准化运行环境。该镜像基于 OpenJDK 源码构建,支持多版本、多架构部署,适用于开发、测试及生产环境中各类 Java 应用的容器化需求。
docker run、docker-compose)拉取最新版本(默认对应最新 LTS 版本):
bashdocker pull noenv/openjdk:latest
指定 Java 版本(如 Java 17):
bashdocker pull noenv/openjdk:17
查看所有可用标签:https://hub.docker.com/r/noenv/openjdk/tags
运行 JAR 应用
挂载本地 JAR 文件并执行:
bashdocker run -it --rm \ -v $(pwd)/app.jar:/app/app.jar \ noenv/openjdk:17 \ java -jar /app/app.jar
自定义 JVM 参数
通过环境变量传递内存配置等参数:
bashdocker run -d --name java-service \ -p 8080:8080 \ -v $(pwd)/app.jar:/app.jar \ -e JAVA_OPTS="-Xms512m -Xmx1g -XX:+UseContainerSupport" \ noenv/openjdk:17 \ java $JAVA_OPTS -jar /app.jar
创建 docker-compose.yml 配置文件:
yamlversion: '3.8' services: java-app: image: noenv/openjdk:17 container_name: java-app restart: always ports: - "8080:8080" volumes: - ./app:/app # 挂载应用代码/配置 - app-logs:/var/log/app # 持久化日志 environment: - JAVA_OPTS="-Xmx1g -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/var/log/app/dump.hprof" - TZ=Asia/Shanghai # 设置时区 working_dir: /app command: java $JAVA_OPTS -jar app.jar volumes: app-logs: # 声明持久化卷
启动服务:
bashdocker-compose up -d
| 环境变量 | 描述 | 默认值 | 示例 |
|---|---|---|---|
JAVA_HOME | Java 安装路径(只读) | /usr/lib/jvm/default-jvm | - |
JAVA_OPTS | 自定义 JVM 参数 | 空 | -Xms256m -Xmx512m -Duser.timezone=UTC |
WORKDIR | 容器工作目录 | / | /app |
USER | 运行用户(UID/GID 或用户名) | root | 1000:1000(非 root 用户) |
TZ | 系统时区 | UTC | Asia/Shanghai |
noenv/openjdk:8)。docker volume 或宿主机挂载持久化。--memory、--cpus 参数限制容器资源,避免 JVM 内存溢出。-u 参数指定 UID/GID),降低权限风险。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务