Are you sure you want to delete the question?

Leaving a resolved question undeleted may help others!

【Java】Mac で Java を利用するときに注意すべきエラーと対処法

Q&A

Closed

※ 間違って「Q&A」に投稿してしまったので、「記事」に再掲します🙇‍♂️

概要

macOS で、PC ゲームの「Minecraft(マイクラ)」の Java版に Mod を導入しようと思って、使用 PC で初めて Java を利用した際に発生したエラーに対する対処法の備忘録。

前提

OS: macOS 13.3.1 (Ventura)
CPU: 3.2GHz 8コア Intel Xeon W

発生した事象

Mod を導入するための前提 Mod 「Minecraft Forge」 を導入するため、そのインストーラ(forge-1.20.2-48.0.37-installer.jar)をダウンロードしてダブルクリックで実行したら、以下のエラーメッセージが発生。

「Mod」とは、一般には、ゲームを拡張・変更する非公式のプログラムやソフトウェアのこと。

操作を完了できませんでした。
Unable to locate a Java Runtime.
Please visit http://www.java.com for information on installing Java.

javaインストールエラー.png

Java は Mac に入っているのに Java が動かない

Java が入ってないのかと思ったけど、PC にデフォルトで入ってる Java はいた

# バージョン確認
$ java --version

# 結果。Java は入っているようだ
openjdk 20.0.1 2023-04-18
OpenJDK Runtime Environment Homebrew (build 20.0.1)
OpenJDK 64-Bit Server VM Homebrew (build 20.0.1, mixed mode, sharing)

コマンドなら起動した

jar ファイルを直接コマンドで叩けば動きはした。

# 同じファイルをコマンドで実行
$ java -jar forge-1.20.2-48.0.37-installer.jar
 
# 動いた。これの後に GUI のダイアログも起動した。
JVM info: Homebrew - 20.0.1 - 20.0.1
java.net.preferIPv4Stack=true
Current Time: 13/11/2023 21:07:11
Host: files.minecraftforge.net [ xxx.xxx.xxx.xxx ]
Host: maven.minecraftforge.net [ xxx.xxx.xxx.xxx ]
Host: libraries.minecraft.net [ xxx.xxx.xxx.xxx ]
Host: launchermeta.mojang.com [ xxx.xxx.xxx.xxx ]
Host: piston-meta.mojang.com [ xxx.xxx.xxx.xxx ]
Host: authserver.mojang.com [ xxx.xxx.xxx.xxx, xxx.xxx.xxx.xxx ]

しかし、今後のことを考えて、同様のファイルのダブルクリックでも動くようにはしておきたいので、対処することにした。

原因

まず、Homebrew で入れた Java を確認すると、openjdk としてインストールされている。

# インストールパッケージ 一覧確認コマンド
$ brew list

==> Formulae
...(略)...    openjdk

次に、openjdk の詳細を確認。…すると、原因がわかった。

# パッケージ詳細確認コマンド
$ brew info openjdk

# 結果
==> openjdk: stable 20.0.1 (bottled) [keg-only]
Development kit for the Java programming language
https://openjdk.java.net/
/usr/local/Cellar/openjdk/20.0.1 (636 files, 322.4MB)
  Poured from bottle using the formulae.brew.sh API on 2023-05-15 at 02:11:59
From: https://github.com/Homebrew/homebrew-core/blob/HEAD/Formula/o/openjdk.rb
License: GPL-2.0-only with Classpath-exception-2.0
==> Dependencies
Build: autoconf ✔, pkg-config ✔
Required: giflib ✔, harfbuzz ✘, jpeg-turbo ✘, libpng ✘, little-cms2 ✘
==> Requirements
Build: Xcode (on macOS) ✔
Required: macOS >= 10.15 (or Linux)==> Caveats
For the system Java wrappers to find this JDK, symlink it with
  sudo ln -sfn /usr/local/opt/openjdk/libexec/openjdk.jdk /Library/Java/JavaVirtualMachines/openjdk.jdk

openjdk is keg-only, which means it was not symlinked into /usr/local,
because macOS provides similar software and installing this software in
parallel can cause all kinds of trouble.

If you need to have openjdk first in your PATH, run:
  echo 'export PATH="/usr/local/opt/openjdk/bin:$PATH"' >> ~/.zshrc

For compilers to find openjdk you may need to set:
  export CPPFLAGS="-I/usr/local/opt/openjdk/include"
==> Analytics
install: 104,786 (30 days), 298,245 (90 days), 657,877 (365 days)
install-on-request: 58,928 (30 days), 166,877 (90 days), 389,585 (365 days)
build-error: 388 (30 days)

結果の一行目に 「keg-only」 とある。
つまり、以下の過去記事でも情報を載せているが、openjdk は Keg-only = 「パッケージのインストール先(Keg)と実体ファイルがあるだけで、実行動作に必要なシンボリックリンクは作成しないタイプのもの」 であったようだ。

プログラムはインストールしてるけど動作に必要な設定は自動で行われないということを意味する。

参考

対処法・解決策

info の結果にある「Caveats」にあるように、表示された内容に従って各種コマンドをそのまま実行していく。

/usr/local にシンボリックリンクを設定する

sudo ln -sfn /usr/local/opt/openjdk/libexec/openjdk.jdk /Library/Java/JavaVirtualMachines/openjdk.jdk

PC の設定ファイル~/.zshrc に設定を追加する(未設定の場合のみ)
cat ~/.zshrc でPATHが未設定の場合のみ実行すれば良い。

# PATH 設定
echo 'export PATH="/usr/local/opt/openjdk/bin:$PATH"' >> ~/.zshrc
echo 'export CPPFLAGS="-I/usr/local/opt/openjdk/include"' >> ~/.zshrc

# 設定の反映
source ~/.zshrc

また、JAVA_HOME の設定は 不要のようだ。

これでさっきの jar ファイルをもう一度起動してみる。
どうやら成功した!ちゃんと起動する
java導入成功.png

その他の方法

別の Java パッケージをインストールする。こちらのシリーズは追加設定がいらない様子。

# cask でインストール
brew cask install java

# adoptopenjdk でインストール
brew cask install adoptopenjdk

まとめ

つまり、「デフォルトの Java 使う時は、シンボリックリンクを貼ればオッケー」ということでした。

1

1Answer

Comments

  1. 良記事ありがとうございます

  2. @to3izo

    Questioner

    @jinbei230525
    ほんとですね、完全に間違っておりました。ご指摘ありがとうございます。移動します!

  3. @to3izo

    Questioner

    @nagayaoh
    コメントありがとうございます!こちら記事を本来の場所に移動しますので、Q&Aはクローズします。お手数おかけしてすみません🙇‍♂️

Your answer might help someone💌