多项目开发环境:如何使用update-alternatives管理多版本Java JDK?(Windows、Mac、Ubuntu)

多项目开发环境:如何使用update-alternatives管理多版本Java JDK?(Windows、Mac、Ubuntu)

如何使用update-alternatives管理多版本Java JDK?(Windows、Mac、Ubuntu)

📖 摘要

在实际开发中,往往会遇到既要维护老项目又要跟进新特性的场景,这就需要在一台机器上同时安装并切换多个Java JDK版本。本文将针对三大主流平台——Windows、macOS 和 Ubuntu,详细介绍如何安装多个 JDK,并使用各自平台上的“替代方案”工具来管理与切换。

  • Windows:通过系统环境变量与批处理脚本实现版本切换
  • macOS:利用 /usr/libexec/java_home 与 jEnv 工具
  • Ubuntu:深入剖析 update-alternatives 原理与实战

无论您是新手还是有一定经验的开发者,都能从中获得清晰的思路与操作指南。

在这里插入图片描述

文章目录

📗 引言

多版本 JDK 切换为何如此重要?兼容性测试:老项目可能依赖 Java 8,而新项目需要 Java 17。生态差异:Spring Boot 2.x 与 3.x 对 Java 版本的要求不同。CI/CD 集成:自动化构建需要在不同 JDK 下验证构建过程。

三大平台各有生态与管理方式,因此本文将分别展开,帮助您在不同系统上搭建灵活的多版本 Java 环境。


作者名片 ✍️博主:猫头虎全网搜索关键词:猫头虎作者微信号:Libin9iOak作者公众号:猫头虎技术团队更新日期:2025年07月21日🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能!

加入我们AI共创团队 🌐

加入猫头虎的共创圈,一起探索编程世界的无限可能! 🚀


猫头虎分享No bug

正文


1. 🪟 Windows 平台

1.1 环境变量基础

Windows 管理可执行程序的核心是 系统路径(PATH)环境变量(Environment Variables)。切换 JDK 版本,本质上就是让系统在 PATH 中优先找到对应版本的 java.exejavac.exe

1.2 安装多个 JDK

  1. 从 Oracle 官网或 AdoptOpenJDK 下载所需版本的 Windows 安装包(.exe)。
  2. 依次安装到不同目录,如:
    • C:\Program Files\Java\jdk1.8.0_381
    • C:\Program Files\Java\jdk-17.0.7

1.3 手动切换

  1. 打开系统环境变量
    • 右键「此电脑」→「属性」→「高级系统设置」→「环境变量」。
  2. 找到 系统变量 中的 JAVA_HOMEPath
    • 修改 JAVA_HOME 为目标 JDK 目录。
    • Path 里,将 %JAVA_HOME%\bin 放到最前面。
  3. 点击「确定」,重新打开命令行窗口,即可 java -version 验证。

1.4 使用批处理脚本自动切换

为了避免每次手动修改环境变量,可编写简单的 .bat 脚本:

@echo off REM 切换到 Java 8 setx JAVA_HOME "C:\Program Files\Java\jdk1.8.0_381" /M setx PATH "%%JAVA_HOME%%\bin;%%PATH%%" /M echo 已切换到 Java 8 
  • 保存为 switch-to-java8.bat,右键以管理员身份运行。
  • 同理可写 switch-to-java17.bat
  • 运行后重启命令行窗口即可生效。

2. 🍎 macOS 平台

2.1 /usr/libexec/java_home 命令

macOS 自带命令 /usr/libexec/java_home,可列出并切换已安装的 JDK 版本。

# 列出所有已安装JDK /usr/libexec/java_home -V # 切换到 Java 11exportJAVA_HOME=$(/usr/libexec/java_home -v 11)exportPATH=$JAVA_HOME/bin:$PATH
  • -V:显示版本列表及安装路径。
  • -v <version>:选择指定版本。

将上述两行写入 ~/.zshrc~/.bash_profile,并配合 alias:

aliasj8='export JAVA_HOME=$(/usr/libexec/java_home -v 1.8)'aliasj11='export JAVA_HOME=$(/usr/libexec/java_home -v 11)'aliasj17='export JAVA_HOME=$(/usr/libexec/java_home -v 17)'

打开新终端后,输入 j11 即可切换。

2.2 使用 jEnv 统一管理(推荐)

jEnv 是跨平台的 Java 版本管理工具,支持 macOS、Linux。

列出与切换:

jenv versions jenv global 11# 全局切换到 Java 11 jenv local1.8.# 针对当前目录切换到 Java 1.8 jenv shell 17# 仅对当前 shell 有效

添加已安装的 JDK:

jenv add /Library/Java/JavaVirtualMachines/jdk1.8.0_381.jdk/Contents/Home jenv add /Library/Java/JavaVirtualMachines/jdk-17.0.7.jdk/Contents/Home 

将 jEnv 集成到 shell 配置:

echo'export PATH="$HOME/.jenv/bin:$PATH"'>> ~/.zshrc echo'eval "$(jenv init -)"'>> ~/.zshrc source ~/.zshrc 

安装 jEnv(需先安装 Homebrew):

brew install jenv 

jEnv 会自动管理 JAVA_HOMEPATH,并支持插件扩展(Maven、Gradle 插件等)。


3. 🐧 Ubuntu 平台(Debian系)

3.1 update-alternatives 原理

  • Debian/Ubuntu 引入 alternatives 系统,允许对系统命令(如 javajavac)创建“组”,并在组内注册多个“备选项”。
  • 每个备选项由 可执行文件路径优先级 组成。
  • 运行 update-alternatives --config <name> 即可交互式切换。

3.2 安装与注册 JDK

3.2.1 使用 APT 安装(OpenJDK)
sudoapt update sudoaptinstall -y openjdk-8-jdk openjdk-11-jdk openjdk-17-jdk 

APT 安装后通常会自动注册到 alternatives,您可以直接执行下一步。

3.2.2 手动下载并注册 Oracle JDK
    • 第三个参数为命令组名(可省略后缀)。
    • 最后一个数字为优先级,数值越大越优先。

注册到 alternatives(以 Java 17 为例,优先级设为 2):

sudo update-alternatives --install /usr/bin/java java /usr/lib/jvm/jdk-17.0.7/bin/java 2sudo update-alternatives --install /usr/bin/javac javac /usr/lib/jvm/jdk-17.0.7/bin/javac 2sudo update-alternatives --install /usr/bin/jar jar /usr/lib/jvm/jdk-17.0.7/bin/jar 2

下载并解压到 /usr/lib/jvm

sudomkdir -p /usr/lib/jvm sudotar -xzf ~/Downloads/jdk-17.0.7_linux-x64_bin.tar.gz -C /usr/lib/jvm 

3.3 切换与查看

查看当前注册项
update-alternatives --query java 

输出包含所有 java 备选路径及当前选择。

交互式切换
sudo update-alternatives --config java 

会列出所有已注册的 Java 可执行文件,按提示输入对应序号即可切换。
同理切换 javacjar 等。


4. ✅ 验证与示例

无论在哪个平台,切换后都应首先验证:

java -version javac -version 

并可编写最简单的 HelloWorld 程序进行编译与运行测试。


5. 🛠️ 常见问题与解决

场景原因与排查解决思路
切换后 java -version 仍指向旧版本PATH 未更新或 shell 缓存未刷新重新打开终端;Windows 重启 CMD;Linux hash -r
Windows 脚本执行报 “权限不足”未以管理员身份运行 .bat右键 → “以管理员身份运行”
macOS /usr/libexec/java_home 列不全JDK 未正确安装到 /Library/Java/...检查 JDK 文件夹;重启 shell
Ubuntu 手动注册后未见新选项alternatives 配置不一致再次执行 --install;检查路径拼写

6. ❓ 常见 QA

  • Q:为什么 Linux 上要用 update-alternatives
    A:它能同时管理多个版本的同名命令,避免手动修改 PATH,且支持优先级与脚本化。
  • Q:Windows 有没有类似 update-alternatives 的工具?
    A:官方没有,但可借助 jabba 或自定义批处理脚本。
  • Q:macOS 上除了 jEnv 还有其他方案吗?
    A:也可使用 SDKMAN! 管理,但 SDKMAN! 对 Windows 支持有限。

🏁 总结

本文深入对比了 Windows、macOS 和 Ubuntu 三大平台上多版本 Java JDK 管理的思路与实践:

  • Windows:环境变量 + 批处理脚本
  • macOS:/usr/libexec/java_home + jEnv
  • Ubuntu:update-alternatives 原理详解

掌握上述方法后,无论在本地开发还是在 CI/CD 环境,都能灵活切换 JDK 版本,确保兼容性与高效协同开发。祝您 Java 开发之路顺畅!🚀

猫头虎

粉丝福利


👉更多信息:有任何疑问或者需要进一步探讨的内容,欢迎点击文末名片获取更多信息。我是猫头虎博主,期待与您的交流! 🦉💬


联系我与版权声明 📩

  • 联系方式
    • 微信:Libin9iOak
    • 公众号:猫头虎技术团队
  • 版权声明
    本文为原创文章,版权归作者所有。未经许可,禁止转载。更多内容请访问猫头虎的博客首页

点击✨⬇️下方名片⬇️✨,加入猫头虎AI共创社群矩阵。一起探索科技的未来,共同成长。🚀

🔗 猫头虎抱团AI共创社群 | 🔗 Go语言VIP专栏 | 🔗 GitHub 代码仓库 | 🔗 Go生态洞察专栏✨ 猫头虎精品博文

在这里插入图片描述

Read more

100天精通Python(爬虫篇)——第122天:基于selenium接管已启动的浏览器(反反爬策略)

100天精通Python(爬虫篇)——第122天:基于selenium接管已启动的浏览器(反反爬策略)

文章目录 * 1、问题描述 * 2、问题推测 * 3、解决方法 * 3.1 selenium自动启动浏览器 * 3.2 selenium接管已启动的浏览器 * 3.3 区别总结 * 4、代码实战 * 4.1 手动方法(手动打开浏览器输入账号密码) * 4.2 自动方法(.bat文件启动的浏览器) 1、问题描述 使用selenium自动化测试爬取pdd的时候,通过携带cookie登录或者控制selenium输入账号密码登录,都出现了:错误代码10001:请求异常请升级客户端后重新尝试 2、问题推测 这个错误的产生是由于pdd可以检测selenium自动化测试的脚本,因此可以阻止selenium的继续访问。现在大厂网站基本上都能检测到selenium脚本了。 3、解决方法 直接用selenium启动浏览器会被检测到,博主测试用selenium接管已经启动的浏览器就不会(原因:接管已经启动的浏览器所携带的浏览器指纹 ≈ 正常访问的浏览器指纹) 使用selenium自动启动浏览器和接管已启动的浏览器,在浏览器指纹方面存

By Ne0inhk
大学生期末项目-springboot+vue+mysql-实现学生信息管理系统_学生教学管理系统【原创】

大学生期末项目-springboot+vue+mysql-实现学生信息管理系统_学生教学管理系统【原创】

目录 一.登录界面 二.登录后欢迎界面  三.  学生管理界面  四. 教师管理界面 五. 数据统计图界面 六.管理员个人信息界面 七. 贴部分代码【不用看】 八. 总结【不用看】  一.登录界面 【背景图可以自己更改,运行视频中有讲解】   项目视频: 学生管理系统演示 二.登录后欢迎界面  这里用到了echarts,如果不知道是什么,老师问你怎么做的,你就说用echarts做的,或者说AI生成的死数据也可以。    三.  学生管理界面 功能基本完善,老师会觉得你vue学的很好,因为这里灵活运用了很基础的语法,麻雀虽小,五章俱全,嘿嘿。   四. 教师管理界面 这里我已经是最简单的版本给你们了,修改那边本来很复杂的,用到了阿里云OSS,但是这边源代码去掉了,让你们配置更加的简单。  五. 数据统计图界面 这里用到了echarts

By Ne0inhk
MySQL必备基础

MySQL必备基础

MySQL必备基础 * DML-插入 * DML-更新和删除 * DQL-基础查询 * DQL-条件查询 * DQL-聚合函数 * DQL-分组查询 * DQL-排序查询 * DQL-分页查询 * DQL-案例联系 * DQL-执行顺序 * DQL-小结 * DCL-用户管理 * DCL-权限控制 * DCL-小结 * 函数-字符串函数 * 函数-数据函数 * 函数-日期函数 * 函数-流程函数 * 约束-概述 * 约束-外键约束 * 约束-小结 * 多表关系介绍 * 多表查询概述 * 内连接 * 外连接 * 自连接 * 联合查询 union * 子查询 * 标量子查询 * 列子查询 * 行子查询 * 表子查询 * 事务简介 * 事务演示 * ACID四大特性 * 并发事务问题 * 隔离级别

By Ne0inhk