只需安装JDK即可,因JRE已集成其中;Java 11起Oracle停供独立JRE,OpenJDK版本亦不提供;Java 9+用jlink定制运行时替代传统JRE。

开发用 JDK,运行用 JRE —— 但绝大多数情况下,你只需要装 JDK 就够了,JRE 已经被 JDK 包含,且从 Java 11 起 Oracle 官方不再单独提供 Windows/macOS 的 JRE 下载。
为什么现在基本不用单独装 JRE
Java 11 是分水岭:Oracle 停止为桌面端发布独立 JRE 安装包;OpenJDK 社区版本(如 Temurin、Zulu)也默认不提供 JRE 构建。所谓“JRE”,实际是 JDK 中的 jre 子目录(Java 8 及以前)或更轻量的 jlink 自定义运行时(Java 9+)。
- Java 8:JDK 安装后自带
JAVA_HOME/jre/目录,可直接当 JRE 用 - Java 9+:JDK 不再附带
jre文件夹,但可通过jlink工具按需生成最小化运行时,例如:jlink --module-path $JAVA_HOME/jmods --add-modules java.base,java.desktop --output myjre
- 部署场景中若真需要精简运行环境,应优先用
jlink生成定制镜像,而不是找“JRE 安装包”——后者早已过时或不可信
JDK 和 JRE 在 PATH 和 JAVA_HOME 上怎么配
JAVA_HOME 必须指向 JDK 根目录(如 C:\Program Files\Java\jdk-17.0.2),不能指向其下的 jre 子目录(Java 8 兼容写法)或任意 runtime 目录;否则 javac 会报错“command not found”或 tools.jar 找不到。
-
PATH中应包含$JAVA_HOME/bin,这样java、javac、jlink等命令才可用 - 不要把
JAVA_HOME设成C:\...\jdk-17.0.2\jre—— 这在 Java 9+ 根本不存在,在 Java 8 下会导致javac失效 - 验证方式:
echo $JAVA_HOME # Linux/macOS
两个 version 输出一致且不报错,说明配置正确
java -version
javac -version
运行 Java 程序时,到底用的是哪个“Java”
真正决定运行行为的是启动命令调用的 java 可执行文件路径,而非 JAVA_HOME —— 后者只是开发工具链(如 Maven、IDEA)用来定位 javac 或 tools.jar 的辅助变量。
立即学习“Java免费学习笔记(深入)”;
- 如果你双击
xxx.jar运行,系统用注册表(Windows)或/usr/bin/java(Linux)或/usr/libexec/java_home(macOS)找默认java,和JAVA_HOME无关 - 如果你执行
java -jar app.jar,Shell 查PATH找第一个java,可能来自 JDK、JRE、或 SDKMAN 安装的某个版本 - IDE(如 IntelliJ)默认用项目配置的 JDK,但运行配置里可单独指定
JRE—— 这里的 “JRE” 实际是 JDK 的一个引用别名,不是独立安装包
真正容易出问题的地方在于:误以为“装了 JRE 就能编译”,结果 javac 找不到;或者在 CI/CD 中用 jlink 生成的运行时没包含 java.desktop 模块,却去跑 Swing 程序——这些都不是“选 JDK 还是 JRE”的问题,而是对模块化和运行时构成的理解偏差。










