ubuntu 上安装 jdk 应避免 apt install default-jdk,因其提供 canonical 定制的 openjdk(如 ubuntu-122.04.1),与 temurin/zulu 等生产推荐版本存在兼容性差异;推荐使用 sdkman! 安装 eclipse temurin 或手动解压官方 tar.gz 包,并确保 java_home 正确指向且被所有服务识别。

Ubuntu 上装 JDK,别碰 apt install default-jdk —— 它默认装的是 OpenJDK 11 或 17(取决于 Ubuntu 版本),但很多后端服务(比如旧版 Spring Boot、某些 Kafka 组件、内部中间件)明确要求 JDK 8 或 JDK 17+ LTS 且需特定厂商版本(如 Temurin、Zulu),直接用系统包容易 runtime 报错或启动失败。
怎么确认当前 JDK 是不是你要的版本和供应商
很多人装完以为完事了,结果跑 java -version 看到一串数字就放心,其实关键信息藏在第二行:
openjdk version "17.0.9" 2023-10-17 OpenJDK Runtime Environment (build 17.0.9+9-Ubuntu-122.04.1) OpenJDK 64-Bit Server VM (build 17.0.9+9-Ubuntu-122.04.1, mixed mode, sharing)
注意第二行末尾的 Ubuntu-122.04.1 —— 这是 Canonical 打的包,和官方 Adoptium/Temurin 的构建行为、TLS 默认策略、甚至 GC 日志格式都有差异。生产环境建议用 temurin 或 zulu。
- 检查是否为 Temurin:运行
java -version,输出含Eclipse Temurin才算 - 检查 JAVA_HOME 是否指向正确路径:
echo $JAVA_HOME,它必须是 JDK 根目录(如/opt/java/jdk-17.0.9+9),不能是/usr/lib/jvm/java-17-openjdk-amd64这类符号链接混乱的系统路径 - 验证
javac是否可用:which javac,如果返回空,说明只装了 JRE,不是 JDK
用 SDKMAN! 装 Temurin JDK(推荐给开发/测试服务器)
SDKMAN! 是最轻量、可切换多版本、且不污染系统 PATH 的方式,适合需要频繁换 JDK 的场景(比如同时跑 Java 8 和 Java 17 的微服务)。
立即学习“Java免费学习笔记(深入)”;
- 安装 SDKMAN!:
curl -s "https://get.sdkman.io" | bash,然后执行source "$HOME/.sdkman/bin/sdkman-init.sh" - 列出可用 JDK:
sdk list java,找带temurin标签的(如17.0.9-amzn是 Amazon Corretto,17.0.9-tem才是 Eclipse Temurin) - 安装并设为默认:
sdk install java 17.0.9-tem && sdk default java 17.0.9-tem - 验证:
java -version应显示Eclipse Temurin;$JAVA_HOME会自动指向~/.sdkman/candidates/java/current
⚠️ 注意:SDKMAN! 默认只对当前 shell 生效,如果用 systemd 启动 Java 服务(比如用 systemctl start myapp.service),得在 service 文件里显式写死 Environment="JAVA_HOME=/home/ubuntu/.sdkman/candidates/java/current",否则它根本找不到 JDK。
手动解压安装(适合生产服务器、无外网或需统一管控)
从 https://www.php.cn/link/e387385ebe0dbeefed3e8e9f3968aaba 下载 tar.gz 包(选 x64_jdk,Linux x64),比 apt 更可控,也避免 Canonical 包的 patch 差异。
- 下载后解压到固定位置,例如:
sudo tar -xzf temurin-17.0.9+9.tar.gz -C /opt/java/ - 设置全局环境变量:编辑
/etc/profile.d/java.sh,写入两行:export JAVA_HOME=/opt/java/jdk-17.0.9+9export PATH=$JAVA_HOME/bin:$PATH - 生效配置:
source /etc/profile.d/java.sh,再检查java -version和javac -version
⚠️ 常见坑:/opt/java/jdk-17.0.9+9 这个路径里有 + 号,某些老旧脚本(比如某些 Shell 启动包装脚本)没做引号包裹,会把 + 当作通配符展开,导致找不到命令。解决办法是重命名目录去掉 +(如 jdk-17.0.9_9)再重新设 JAVA_HOME。
真正麻烦的从来不是“装上”,而是“所有依赖它的服务都认得这个 JDK”。Tomcat、Kafka、Elasticsearch 的启动脚本可能硬编码 JAVA_HOME,也可能读系统环境变量,还可能被 systemd 的 EnvironmentFile 覆盖——得一个个查清楚它们实际加载的是哪个 JAVA_HOME,而不是只信 echo $JAVA_HOME 的结果。










