多项目开发环境:如何使用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

今日AI榜单速览(GitHub Trending AI Top3)

今日AI榜单速览(GitHub Trending AI Top3)

🔥 个人主页:杨利杰YJlio❄️ 个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》《Python》《Kali Linux》《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更简单,让重复的工作自动化 今日AI热榜 * 1 1 今日榜单速览(GitHub Trending AI Top3) * 2 2 ruvnet / RuView:WiFi DensePose 的“无线透视”路线 * 2 我的一句话总结 * 2 为什么今天它能冲到第一? * 2 图:它的可视化界面长这样(很直观) * 2 我如何最快验证(不折腾工具链) * 3 3 K-Dense-AI / claude-scientific-skills:给

By Ne0inhk
VsCode远程连接服务器后安装Github Copilot无法使用

VsCode远程连接服务器后安装Github Copilot无法使用

VsCode远程连接服务器后安装Github Copilot无法使用 1.在Vscode的settings中搜索Extension Kind,如图所示: 2.点击Edit in settings.json,添加如下代码: "remote.extensionKind":{"GitHub.copilot":["ui"],"GitHub.copilot-chat":["ui"],} remote.extensionKind 的作用 这是 VS Code 的远程开发配置项,用于控制扩展在远程环境(如 SSH、容器、WSL)中的运行位置。可选值: “ui”:扩展在本地客户端运行 “workspace”:扩展在远程服务器运行 这两个扩展始终在 本地客户端运行,

By Ne0inhk

VS Code 中 Git 的使用:从零到一保姆级菜鸟教程

VS Code 中 Git 的使用:从零到一保姆级菜鸟教程 前言 在现代软件开发中,版本控制是必不可少的技能。VS Code 作为目前最流行的代码编辑器,其内置的 Git 可视化工具让代码管理变得极其直观和简单。 本文将带你从零开始,跑通“下载安装 -> 环境配置 -> GitHub 关联 -> 提交推送 -> 冲突解决”的全流程。告别繁琐的命令行,用可视化的方式优雅地管理代码! 1. 软件下载与基础配置 1.1 下载地址 * VS Code 官方下载:https://code.visualstudio.com/Download * Git 官方下载 (Windows

By Ne0inhk
Flutter 三方库 better_commit 的鸿蒙化适配指南 - 实现具备语义化提交规范与自动化交互的 Git 工作流插件、支持端侧版本工程的高效规范化审计实战

Flutter 三方库 better_commit 的鸿蒙化适配指南 - 实现具备语义化提交规范与自动化交互的 Git 工作流插件、支持端侧版本工程的高效规范化审计实战

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 better_commit 的鸿蒙化适配指南 - 实现具备语义化提交规范与自动化交互的 Git 工作流插件、支持端侧版本工程的高效规范化审计实战 前言 在进行 Flutter for OpenHarmony 开发时,当团队规模扩大到需要多人协同、频繁提交代码时,凌乱的 Commit Message 会让 Git 历史变得难以审计(如:分不清哪些是功能修复、哪些是底层鸿蒙适配)。better_commit 是一款专注于极致规范化提交的 CLI 增强工具。本文将探讨如何在鸿蒙端构建极致、专业的工程化提交标准。 一、原直观解析 / 概念介绍 1.1 基础原理 该库建立在“Angular 提交规范”之上。它通过交互式的命令行引导(

By Ne0inhk