JDK未安装或环境变量未配置导致“java: command not found”,需下载OpenJDK 17、解压至/usr/lib/jvm、创建软链接、配置/etc/profile.d/java.sh中的JAVA_HOME与PATH,并验证java -version等命令。

如果您在Linux系统中需要运行Java应用程序,但系统提示“java: command not found”,则说明JDK尚未安装或环境变量未正确配置。以下是完成JDK安装与Java环境变量配置的实操步骤:
一、下载JDK安装包
Oracle JDK已停止公开免费更新,推荐使用OpenJDK或Azul Zulu等开源、可免费商用的JDK发行版。本教程以OpenJDK 17为例,适用于Ubuntu/Debian及CentOS/RHEL系发行版。
1、访问Adoptium官网(https://adoptium.net/)或使用wget直接下载对应架构的tar.gz包,例如x64 Linux版本:wget https://github.com/adoptium/temurin17-binaries/releases/download/jdk-17.0.1%2B12/OpenJDK17U-jdk_x64_linux_hotspot_17.0.1_12.tar.gz。
2、确认下载完成,执行ls -l *.tar.gz检查文件是否存在。
立即学习“Java免费学习笔记(深入)”;
3、创建统一安装目录:sudo mkdir -p /usr/lib/jvm。
二、解压并安装JDK
将下载的JDK压缩包解压至系统级JVM目录,确保所有用户均可访问该路径,且路径结构清晰便于后续配置。
1、进入下载目录(如~/Downloads),执行:sudo tar -xzf OpenJDK17U-jdk_x64_linux_hotspot_17.0.1_12.tar.gz -C /usr/lib/jvm/。
2、解压后查看目录名:ls /usr/lib/jvm/,输出类似jdk-17.0.1+12的文件夹。
3、为该目录创建规范软链接以便版本管理:sudo ln -sfn /usr/lib/jvm/jdk-17.0.1+12 /usr/lib/jvm/java-17。
三、配置全局JAVA_HOME环境变量
通过修改系统级配置文件,使所有登录用户(包括shell脚本与服务)均能识别JAVA_HOME和PATH,避免仅当前会话生效的问题。
1、编辑系统环境变量文件:sudo nano /etc/profile.d/java.sh(若不存在则新建)。
2、在该文件中写入以下两行内容:export JAVA_HOME=/usr/lib/jvm/java-17。
3、继续写入:export PATH=$JAVA_HOME/bin:$PATH。
4、保存退出后,立即加载新配置:source /etc/profile.d/java.sh。
四、验证JDK安装与环境变量
通过命令行逐项验证JDK是否被正确识别、版本是否匹配、环境变量是否生效,排除路径错误或权限问题。
1、检查JAVA_HOME是否设置成功:echo $JAVA_HOME,应输出/usr/lib/jvm/java-17。
2、检查java命令是否可用:java -version,应显示OpenJDK 17.0.1版本信息。
3、检查javac编译器是否就绪:javac -version,输出应与java -version一致。
4、确认PATH中包含JDK bin目录:echo $PATH | grep java,返回结果中应含/usr/lib/jvm/java-17/bin。
五、替代方案:使用包管理器安装(Ubuntu/Debian)
对于Debian系系统,可通过apt直接安装OpenJDK,省去手动下载解压步骤,适合快速部署且无需指定版本细节的场景。
1、更新软件包索引:sudo apt update。
2、安装默认JDK(通常为最新LTS版本):sudo apt install default-jdk。
3、安装完成后自动配置JAVA_HOME,但需手动确认其值:sudo update-alternatives --config java,根据提示选择对应条目。
4、验证JAVA_HOME:readlink -f /usr/bin/java | sed "s:/jre/bin/java::",输出即为实际JAVA_HOME路径。
六、替代方案:使用SDKMAN!管理多版本JDK
SDKMAN!是轻量级工具链管理器,支持一键安装、切换多个JDK版本,适合开发人员频繁测试不同Java版本的场景。
1、安装SDKMAN!:curl -s "https://get.sdkman.io" | bash。
2、初始化SDKMAN!环境:source "$HOME/.sdkman/bin/sdkman-init.sh"。
3、列出可用JDK版本:sdk list java。
4、安装指定版本(如temurin-17.0.1+12):sdk install java 17.0.1-tem。
5、设为默认版本:sdk default java 17.0.1-tem。










