一臺機器下,多個Java版本的粗放與精細管理

ITPUB社群發表於2022-12-12

前言

在軟體開發過程中,經常會遇到“古老”的專案,這些專案的JDK還處於Java 6、Java 7甚至更早的版本。同時,在學習新的JDK特性時,往往又需要安裝最新版本的JDK。鑑於這些情況,我們就需要在在本機環境中安裝多個JDK,並且能夠方便的切換。

本篇文章以Mac OS作業系統為例,演示一下如何安裝多個JDK版本,並且進行切換。這裡重點介紹兩種方式,基於別名的形式和基於jenv軟體的形式。

基於別名的JDK切換

這裡以Mac作業系統下,Java 9為例進行演示。

JDK安裝

下載Mac下Java 9的dmg安裝包,按照步驟一路Next進行安裝即可。

安裝完成,在Mac的/Library/Java/JavaVirtualMachines目錄下會出現兩個(如果安裝多個JDK則有多個)目錄:

jdk-9.0.4.jdk  jdk1.8.0_151.jdk

除了目前比較主流的Java 8之外,新的長期支援版本(LTS)有Java 11和Java 17,大家可根據需要進行按照。上面展示了有兩個JDK版本的情況,其他版本對照即可。

環境變數配置

Mac下可透過bash_profile檔案來對JDK的環境變數進行配置。執行以下命令開啟配置檔案:

vim ~/.bash_profile

如果原本沒有.bash_profile檔案,在執行vim ~/.bash_profile命令時會建立該檔案。

參考原有環境變數配置,新增JDK9的配置:

# Java config
export JAVA_8_HOME="/Library/Java/JavaVirtualMachines/jdk1.8.0_151.jdk/Contents/Home"
export JAVA_9_HOME="/Library/Java/JavaVirtualMachines/jdk-9.0.4.jdk/Contents/Home"

# config alias
alias jdk8="export JAVA_HOME=$JAVA_8_HOME"
alias jdk9="export JAVA_HOME=$JAVA_9_HOME"

# config default jdk
export JAVA_HOME=$JAVA_8_HOME
export PATH="$JAVA_HOME:$PATH"

上面修改了兩處:第一處定義了JAVA_8_HOME和JAVA_9_HOME的Home路徑;第二處配置了jdk8和jdk9的操作的別名(alias)。

儲存上述修改配置,並執行以下命令使bash_profile生效:

source ~/.bash_profile

編譯完成,相關的配置即完成,後續可透過命令來進行JDK的切換。

JDK環境切換

在上述配置中,預設使用的是Java 8,執行java -version命令可驗證:

192:JavaVirtualMachines zzs$ java -version
java version "1.8.0_151"
Java(TM) SE Runtime Environment (build 1.8.0_151-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.151-b12, mixed mode)

當需要切換到Java 9時,執行如下命令即可:

192:JavaVirtualMachines zzs$ jdk9
192:JavaVirtualMachines zzs$ java -version
java version "9.0.4"
Java(TM) SE Runtime Environment (build 9.0.4+11)
Java HotSpot(TM) 64-Bit Server VM (build 9.0.4+11, mixed mode)

此時,已經切換為Java 9了。當然,如果想切換回Java 8,則執行jdk8即可。

透過這種別名的形式,可以配置多個JDK環境,但遇到一些複雜的環境,這種簡單的手動切換就顯得力不從心了。我們需要更加便捷,細粒度的控制工具,這裡推薦JEnv這款工具。

JEnv工具使用

如官網所說JEnv是一款讓你忘記如何配置JAVA_HOME的神器,使用簡單的命令就可以在不同Java版本之間進行切換。下面就來看看JEnv的安裝和基本使用。

JEnv的安裝

在Mac OS下可使用Homebrew安裝JEnv:

brew install jenv

等待上述命令安裝成功後,還需在.bash_profile中進行一下配置。對應的配置內容,在安裝時控制檯也有列印,這裡透過echo命令直接將內容新增到.bash_profile檔案當中:

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

安裝完成,執行命令查詢一下版本資訊:

$ jenv versions
* system (set by /Users/zzs/.jenv/version)

從結果看出,只找到了系統預設的Java,*表示當前選擇的版本。儘管安裝了其他版本的Java,但沒有自動發現。

還是以現在的Java 8和Java 9環境為例,我們透過jenv add命令將對應的Java路徑新增到jenv中:

$ jenv add /Library/Java/JavaVirtualMachines/jdk1.8.0_151.jdk/Contents/Home/
oracle64-1.8.0.151 added
1.8.0.151 added
1.8 added
 1.8.0.151 already present, skip installation

Java 9新增到jenv中:

$ jenv add /Library/Java/JavaVirtualMachines/jdk-9.0.4.jdk/Contents/Home/
oracle64-9.0.4 added
9.0.4 added
9.0 added
 9.0.4 already present, skip installation

此時再執行查詢版本資訊命令:

$ jenv versions
* system (set by /Users/zzs/.jenv/version)
  1.8
  1.8.0.151
  9.0
  9.0.4
  oracle64-1.8.0.151
  oracle64-9.0.4

可以看到Java 8和Java 9的JDK已經新增到jenv當中了。但很明顯,也新增了一些無需的JDK版本,可以透過remove命令將其移除:

$ jenv remove oracle64-1.8.0.151
JDK oracle64-1.8.0.151 removed

當不需要的版本移除之後,再次檢視:

$ jenv versions
* system (set by /Users/zzs/.jenv/version)
  1.8.0.151
  9.0.4

只留下了1.8.0.151和9.0.4這兩個版本。

JEnv的使用

完成了上述安裝,便可以透過命令來切換所使用的Java版本了:

$ jenv local 1.8.0.151
/usr/local/Cellar/jenv/0.5.5_2/libexec/libexec/jenv-version-file-write: line 19: .java-version: Permission denied

在嘗試使用時,並沒有出現預期的效果,報許可權問題,這裡可透過doctor命令來檢視一下原因:

$ jenv doctor
[ERROR] JAVA_HOME variable already set, scripts that use it directly could not use java version set by jenv
[OK] Java binaries in path are jenv shims
[OK] Jenv is correctly loaded

第一行提示JAVA_HOME變數已經配置了,於是編輯.bash_profile檔案註釋掉原來的JAVA_HOME變數,再次執行:

$ jenv doctor
[OK] No JAVA_HOME set
[OK] Java binaries in path are jenv shims
[OK] Jenv is correctly loaded

經過上述操作,發現在切換Java版本時“Permission denied”問題依舊出現,於是退出了命令列視窗,重新開啟問題就消失了。

切換前版本:

$ java -version
openjdk version "17.0.4.1" 2022-08-12
OpenJDK Runtime Environment Temurin-17.0.4.1+1 (build 17.0.4.1+1)
OpenJDK 64-Bit Server VM Temurin-17.0.4.1+1 (build 17.0.4.1+1, mixed mode, sharing)

執行切換,及切換後版本:

$ jenv local 1.8
$ java -version
java version "1.8.0_151"
Java(TM) SE Runtime Environment (build 1.8.0_151-b12)
Java HotSpot(TM) 64-Bit Server VM (build 25.151-b12, mixed mode)

其中jenv local指定了某資料夾中local的Java版本,還可以透過jenv global設定一個預設的Java版本,執行jenv which java顯示可執行的Java的完整路徑。

設定全域性預設版本:

jenv global 1.8

顯示可執行的Java的完整路徑:

$ jenv which java
/Users/zzs/.jenv/versions/1.8/bin/java

也可以在特定的資料夾下使用.java-version檔案來設定Java的版本。

$ cat .java-version
1.8

在執行過jenv local 1.8命令的目錄下,可以看到生成了上述.java-version檔案,並且檔案記憶體儲了Java的版本號。

比如,當在Project中使用Java 8時,僅僅需要把1.8作為內容儲存在.java-version檔案中,當進入該資料夾時,JEnv會自動地幫助我設定local的Java的版本。

PS:在上述操作的過程中,我們需要注意某些時刻未達到預期效果,可能是命令列視窗快取的問題,可嘗試關閉命令列視窗重新開啟進行檢視。

JEnv實踐

這裡透過Idea 2022建立一個基於Java 17的專案java17-learn:

.
├── pom.xml
└── src
    ├── main
    │   ├── java
    │   │   └── com
    │   │       └── secbro2
    │   │           └── Main.java
    │   └── resources
    └── test
        └── java

建立完成之後,進入專案根目錄,執行jenv命令將對應的目錄的環境變數設定為Java 17:

$ jenv local temurin64-17.0.4.1
$ java -version
openjdk version "17.0.4.1" 2022-08-12
OpenJDK Runtime Environment Temurin-17.0.4.1+1 (build 17.0.4.1+1)
OpenJDK 64-Bit Server VM Temurin-17.0.4.1+1 (build 17.0.4.1+1, mixed mode, sharing)

可以看到已經給指定目錄設定了對應的Java版本。此時如果用IDEA開啟專案,會看到專案的根目錄下多一個.java-version的檔案,開啟該檔案,內容為:

temurin64-17.0.4.1

而新建立的這個專案與全域性預設的Java 8的環境變數配置並不衝突,可以各自正常執行。至此,關於JEnv的使用介紹完畢。

小結

本篇文章針對多Java版本環境變數的管理問題,帶大家實踐和學習了兩種環境變數管理方式:一種是比較粗放的,基於環境變數命令別名的形式,透過別名來切換當前的環境變數;另外一種是藉助於三方工具JEnv來完成多Java版本的精確管理,可以細化到具體的檔案目錄。如果條件允許,推薦大家使用JEnv來進行管理。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/70024420/viewspace-2927743/,如需轉載,請註明出處,否則將追究法律責任。

相關文章