应安装 java-17-openjdk-devel 包,它包含 javac、javadoc、jar 和头文件;仅装 java-17-openjdk 运行时会导致 javac 命令未找到。

openSUSE 用 zypper 装 Java 开发包,该选哪个包?
openSUSE 的 Java 包名和别的发行版差别挺大,java-17-openjdk 是运行时,java-17-openjdk-devel 才是开发必需的——它带 javac、javadoc、jar 和头文件。只装前者,javac 命令会报“command not found”。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- 先查可用版本:
zypper search -t package "java.*openjdk.*devel" - 装开发包(以 17 为例):
sudo zypper install java-17-openjdk-devel - 别装
java-17-openjdk-headless单独包——它没javac,也不含图形类支持,纯服务端场景才考虑 - 如果项目需要 Java 11 或 21,把包名里的
17换成对应版本号,但注意 openSUSE Leap 默认仓库通常只维护 LTS 版本(11/17/21),非 LTS(如 20)得加额外仓库
JAVA_HOME 怎么设才不会被系统覆盖?
openSUSE 的 /usr/lib64/jvm/ 下可能有多个 JDK,update-alternatives 会自动管理 java 命令指向,但 JAVA_HOME 不参与这个机制——它必须手动设,且位置要和 java -version 输出的实际路径一致,否则 Maven、Gradle 会找不到编译器。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- 先确认当前生效的 JDK 路径:
readlink -f $(which java),结果类似/usr/lib64/jvm/java-17-openjdk-17.0.1.0.12-150400.3.3.1.x86_64/bin/java,那JAVA_HOME就该是它的上两级目录:/usr/lib64/jvm/java-17-openjdk-17.0.1.0.12-150400.3.3.1.x86_64 - 写进
~/.bashrc或/etc/profile.d/java.sh(后者对所有用户生效):export JAVA_HOME=/usr/lib64/jvm/java-17-openjdk—— 注意这里用的是符号链接名,不是带版本号的完整路径,因为更新后链接会自动指向新版本 - 别在
/etc/environment里设JAVA_HOME:它不支持 shell 变量展开,也不能执行readlink,硬编码路径极易过期
zsh 用户执行 javac 报 “Permission denied” 怎么办?
这不是权限问题,而是 openSUSE 的 java-xx-openjdk-devel 包把 javac 安装为一个 shell wrapper 脚本(位于 /usr/bin/javac),它依赖 java 命令在 PATH 中可用。如果 JAVA_HOME 设错或 PATH 没包含 $JAVA_HOME/bin,脚本执行时会找不到 java,就报 Permission denied(实际是 exec 失败的误导信息)。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- 检查
echo $PATH是否含$JAVA_HOME/bin;没含就补上:export PATH=$JAVA_HOME/bin:$PATH - 验证 wrapper 是否能跑通:
/usr/bin/javac -version,如果还报错,说明JAVA_HOME指向了不存在的路径,或里面没bin/java - zsh 用户特别注意:如果用了 oh-my-zsh 或插件管理器,
~/.zshrc加完变量后要source ~/.zshrc,别只改了文件就以为生效了
Maven 和 IDE 读不到 JAVA_HOME 的常见原因
IntelliJ IDEA、VS Code 的 Java 插件、Maven 默认不读 shell 的 JAVA_HOME,它们要么靠系统级 alternatives,要么自己扫描 /usr/lib64/jvm/。所以即使你 echo $JAVA_HOME 正确,IDE 里新建项目仍可能用错 JDK。
实操建议:
立即学习“Java免费学习笔记(深入)”;
- Maven 项目:在
pom.xml里显式指定编译级别,避免依赖环境变量:<maven.compiler.source>17</maven.compiler.source>和<maven.compiler.target>17</maven.compiler.target> - IntelliJ:File → Project Structure → Project → Project SDK,点 “+” → “Add JDK”,手动选
/usr/lib64/jvm/java-17-openjdk,别信“Detect”按钮 - VS Code + Extension Pack for Java:按 Ctrl+Shift+P → “Java: Configure Java Runtime”,在 “Java Configuration Runtimes” 里添加路径,而不是靠环境变量自动发现
最麻烦的其实是多版本共存时的软链接跳转——java-17-openjdk 这个符号链接本身由 alternatives 管理,但 JAVA_HOME 如果硬编码到具体子目录,一次系统更新就断掉。盯住那个顶层符号链接,比记版本号靠谱。










