「Java」の版間の差分
(同期) |
|||
(7人の利用者による、間の33版が非表示) | |||
1行目: | 1行目: | ||
[[Category:プログラミング言語]] |
[[Category:プログラミング言語]] |
||
− | [[ |
+ | [[Category:Oracle]] |
[[de:Java]] |
[[de:Java]] |
||
[[en:Java]] |
[[en:Java]] |
||
− | [[es:Java]] |
||
− | [[fr:Java]] |
||
− | [[it:Java]] |
||
[[pt:Java]] |
[[pt:Java]] |
||
[[ru:Java]] |
[[ru:Java]] |
||
− | [[ |
+ | [[zh-hans:Java]] |
{{Related articles start}} |
{{Related articles start}} |
||
{{Related|Java パッケージガイドライン}} |
{{Related|Java パッケージガイドライン}} |
||
− | {{Related|Java |
+ | {{Related|Java 実行環境のフォント}} |
{{Related articles end}} |
{{Related articles end}} |
||
[[Wikipedia:ja:Java|Wikipedia]] より: |
[[Wikipedia:ja:Java|Wikipedia]] より: |
||
− | :Java は Sun Microsystems によって開発され1995年に Sun Microsystems の Java プラットフォームのコアコンポーネントとしてリリースされたプログラミング言語です。構文は C および C++ から多くを引き継いでいますが、オブジェクトモデルがシンプルで低水準の機能が削られています。基本的に Java のアプリケーションはコンピュータアーキテクチャに関係なく動く Java 仮想マシン (JVM) で動くバイトコードにコンパイルされます。 |
+ | :Java は Sun Microsystems によって開発され1995年に Sun Microsystems の Java プラットフォームのコアコンポーネントとしてリリースされたプログラミング言語です。構文は C および C++ から多くを引き継いでいますが、オブジェクトモデルがシンプルで低水準の機能が削られています。基本的に Java のアプリケーションはコンピュータアーキテクチャに関係なく動く Java 仮想マシン ([[Wikipedia:ja:Java仮想マシン|JVM]]) で動くバイトコードにコンパイルされます。 |
− | Arch Linux は |
+ | Arch Linux は、オープンソースの [https://openjdk.java.net/ OpenJDK] バージョン 8、11、17、そして 21 を公式にサポートしています。これらの JVM は全てインストールしても衝突せず、ヘルパースクリプト {{ic|archlinux-java}} を使って切り替えることが可能です。他の Java 環境はいくつか [[AUR]] からインストールすることができますが、公式のサポートはありません。 |
== インストール == |
== インストール == |
||
+ | {{Note| |
||
− | {{Note|JDK をインストールすると自動的に依存パッケージとして JRE がインストールされます。}} |
||
+ | * Arch Linux が公式にサポートしているのは [[#OpenJDK|OpenJDK]] 実装だけです。 |
||
+ | * インストール後、Java 環境をシェルに認識させる必要があります ({{ic|$PATH}} 変数)。コマンドラインから {{ic|/etc/profile}} を source するか、デスクトップ環境から一度ログアウトしてログインし直すか、または再起動することで、シェルに認識させることができます。 |
||
+ | }} |
||
+ | 2つの ''共通'' パッケージがそれぞれ依存パッケージとしてインストールされます: {{Pkg|java-runtime-common}} (全ての Java Runtime Environment に共通のファイルが含まれています) と {{Pkg|java-environment-common}} (全ての Java Development Kit に共通のファイルが含まれています) です。提供される環境ファイル {{ic|/etc/profile.d/jre.sh}} は、シンボリックリンクによって参照されている {{ic|/usr/lib/jvm/default/bin}} を指しており、このシンボリックリンクは {{ic|archlinux-java}} ヘルパースクリプトによって設定されます。 |
||
− | {{Note|インストールした後、Java 環境をシェルに認識させる必要があります ({{Ic|$PATH}} 変数)。コマンドラインから {{Ic|/etc/profile}} を source するか、デスクトップ環境ならばログアウトとログインが必要です。}} |
||
+ | {{Warning|シンボリックリンク である {{ic|/usr/lib/jvm/default}} と {{ic|/usr/lib/jvm/default-runtime}} を変更したい場合は、'''必ず''' {{ic|archlinux-java}} を使う必要があります。}} |
||
− | 依存パッケージとして自動的にインストールされる {{Pkg|java-runtime-common}} と {{Pkg|java-environment-common}} という名前の2つの''共通''パッケージには環境ファイル {{Ic|/etc/profile.d/jre.sh}} が入っています。このファイルには全ての JVM 環境で共通の変数が含まれています。また、{{Pkg|java-runtime-common}} パッケージにはデフォルトの Java 環境を表示したり変更することができるユーティリティスクリプト {{Ic|archlinux-java}} も付いています。このスクリプトは衝突しないように {{Ic|/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME} }} にインストールされた Java 環境や Java ランタイムに {{Ic|/usr/lib/jvm/default}} や {{Ic|/usr/lib/jvm/default-runtime}} からリンクを設定します。さらに Java 環境セットによる全ての実行ファイルのために {{Ic|/usr/bin}} にリンクを作成・更新します。 |
||
+ | これは、{{ic|<nowiki>/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME}</nowiki>}} 内のデフォルトの作業 Java 環境や、{{ic|<nowiki>/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME}/jre</nowiki>}} 内の Java ランタイムを表示したり指定したりするために使用されます。 |
||
− | {{Warning|ファイル {{Ic|/etc/profile.d/jdk.sh}} は現在どのパッケージにも入っていません。}} |
||
+ | Java 環境のほとんどの実行ファイルは、{{ic|/usr/bin/}} 内のダイレクトリンクによって提供されます。一方、その他は {{ic|$PATH}} でアクセスできます。{{ic|/etc/profile.d/jdk.sh}} スクリプトは、もはやどのパッケージからも提供されません。 |
||
− | ブラウザで Java を使うには ([[Wikipedia:ja:Javaアプレット|Java アプレット]]や [[Wikipedia:ja:Java Web Start|Java Web Start]])、{{Pkg|icedtea-web}} をインストールしてください。詳しくは [[ブラウザプラグイン#Java (IcedTea)]] を見て下さい。 |
||
+ | === OpenJDK === |
||
− | [[公式リポジトリ]]から以下のパッケージがインストールできます: |
||
+ | [[Wikipedia:ja:OpenJDK|OpenJDK]] は、Java Platform, Standard Edition (Java SE) のオープンソースな実装であり、公式リファレンス実装として指定されています。OpenJDK ビルドには、[https://adoptium.net Adoptium] (以前は AdoptOpenJDK として知られていました) や [https://aws.amazon.com/corretto/ Amazon Corretto] などの複数のディストリビューターが存在しています。Arch Linux の OpenJDK パッケージは[https://hg.openjdk.java.net/ 上流の OpenJDK ソースコード]からビルドされています。 |
||
− | === OpenJDK 7 === |
||
+ | ;ヘッドレス JRE: 最小限の Java 実行環境 - 非 GUI な Java プログラムを実行するために必要。 |
||
− | {| class="wikitable" |
||
+ | ;フル JRE: 完全な Java 実行環境 - Java の GUI プログラムを実行するために必要。 |
||
− | ! パッケージ名 !! 中身 |
||
+ | ;JDK:[[Wikipedia:ja:Java Development Kit|Java Development Kit]] - Java で開発するために必要。 |
||
− | |- |
||
− | |{{Pkg|jre7-openjdk-headless}} || Java 実行環境 (''JRE'') グラフィカルツールなし - バージョン 7 |
||
− | |- |
||
− | |{{Pkg|jre7-openjdk}} || 完全な Java 実行環境 (''JRE'') - バージョン 7 |
||
− | |- |
||
− | |{{Pkg|jdk7-openjdk}} || Java 開発キット (''JDK'') - バージョン 7 |
||
− | |- |
||
− | |{{Pkg|openjdk7-doc}} || OpenJDK javadoc - バージョン 7 |
||
− | |- |
||
− | |{{Pkg|openjdk7-src}} || OpenJDK ソース - バージョン 7 |
||
− | |} |
||
+ | バージョン 21 より前の OpenJDK では、OpenJDK は JRE に依存しており、JRE は ヘッドレス JRE に依存しています。しかし、OpenJDK 21 では、小さいパッケージはサブセットであるため、それぞれのバージョンは互いに衝突します。つまり、OpenJDK 21 では、JDK は JRE を提供すると同時に JRE と衝突し、JRE はヘッドレス JRE を提供すると同時にヘッドレス JRE と衝突します。 |
||
− | === OpenJDK 8 === |
||
{| class="wikitable" |
{| class="wikitable" |
||
+ | ! バージョン !! ヘッドレス JRE !! フル JRE !! JDK !! ドキュメント !! ソース |
||
− | ! パッケージ名 !! 中身 |
||
|- |
|- |
||
+ | | [https://openjdk.java.net/projects/jdk/21/ OpenJDK 21] || {{Pkg|jre-openjdk-headless}} || {{Pkg|jre-openjdk}} || {{Pkg|jdk-openjdk}} || {{Pkg|openjdk-doc}} || {{Pkg|openjdk-src}} |
||
− | |{{Pkg|jre8-openjdk-headless}} || Java 実行環境 (''JRE'') グラフィカルツールなし - バージョン 8 |
||
|- |
|- |
||
+ | | [https://openjdk.java.net/projects/jdk/17/ OpenJDK 17] || {{Pkg|jre17-openjdk-headless}} || {{Pkg|jre17-openjdk}} || {{Pkg|jdk17-openjdk}} || {{Pkg|openjdk17-doc}} || {{Pkg|openjdk17-src}} |
||
− | |{{Pkg|jre8-openjdk}} || 完全な Java 実行環境 (''JRE'') - バージョン 8 |
||
|- |
|- |
||
+ | | [https://openjdk.java.net/projects/jdk/11/ OpenJDK 11] || {{Pkg|jre11-openjdk-headless}} || {{Pkg|jre11-openjdk}} || {{Pkg|jdk11-openjdk}} || {{Pkg|openjdk11-doc}} || {{Pkg|openjdk11-src}} |
||
− | |{{Pkg|jdk8-openjdk}} || Java 開発キット (''JDK'') - バージョン 8 |
||
− | |- |
||
− | |{{Pkg|openjdk8-doc}} || OpenJDK javadoc - バージョン 8 |
||
− | |- |
||
− | |{{Pkg|openjdk8-src}} || OpenJDK ソース - バージョン 8 |
||
|- |
|- |
||
+ | | [https://openjdk.java.net/projects/jdk8/ OpenJDK 8] || {{Pkg|jre8-openjdk-headless}} || {{Pkg|jre8-openjdk}} || {{Pkg|jdk8-openjdk}} || {{Pkg|openjdk8-doc}} || {{Pkg|openjdk8-src}} |
||
|} |
|} |
||
+ | |||
+ | {{App|OpenJDK GA|Oracle による最新 OpenJDK 一般公開リリースビルド。|https://jdk.java.net|{{AUR|java-openjdk-bin}}}} |
||
+ | {{App|OpenJDK EA|Oracle による開発版用の最新 OpenJDK 早期アクセスビルド。|https://jdk.java.net|{{AUR|java-openjdk-ea-bin}}}} |
||
+ | {{App|IcedTea-Web|Java Web Start と非推奨の Java ブラウザプラグイン。|https://icedtea.classpath.org/download/icedtea-web-docs/1.8/html/en/icedtea-web.html|{{Pkg|icedtea-web}}}} |
||
=== OpenJFX === |
=== OpenJFX === |
||
+ | [https://wiki.openjdk.java.net/display/OpenJFX/Main OpenJFX] は、[[Wikipedia:ja:JavaFX|JavaFX]] のオープンソースな実装です。Oracle JDK を使用している場合は、このパッケージをインストールする[https://wiki.openjdk.java.net/display/OpenJFX/Repositories+and+Releases 必要はありません]。このパッケージは、Java のオープンソース実装 (OpenJDK プロジェクト) やその派生版のユーザのみを対象としています。 |
||
− | JavaFX も公式リポジトリからインストールすることができます。OpenJDK 8 が必要です。 |
||
{| class="wikitable" |
{| class="wikitable" |
||
+ | ! バージョン !! 実行環境及び開発環境 !! ドキュメント !! ソース |
||
− | ! パッケージ名 !! 中身 |
||
− | |- |
||
− | |{{Pkg|java-openjfx}} || Java OpenJFX 8 クライアントアプリケーションプラットフォーム (JavaFX のオープンソース実装) |
||
− | |- |
||
− | |{{Pkg|java-openjfx-doc}} || OpenJFX javadoc |
||
|- |
|- |
||
+ | | [https://wiki.openjdk.java.net/display/OpenJFX/Main OpenJFX 21] || {{AUR|java-openjfx}} || {{AUR|java-openjfx-doc}} || {{AUR|java-openjfx-src}} |
||
− | |{{Pkg|java-openjfx-src}} || OpenJFX ソース |
||
|- |
|- |
||
+ | | [https://wiki.openjdk.java.net/display/OpenJFX/Main OpenJFX 17] || {{AUR|java17-openjfx}} || {{AUR|java17-openjfx-doc}} || {{AUR|java17-openjfx-src}} |
||
|} |
|} |
||
+ | {{App|OpenJFX GA|Gluon による最新 OpenJFX 一般公開リリースビルド。|https://openjfx.io/|{{AUR|java-openjfx-bin}}}} |
||
− | == パッケージの out-of-date == |
||
+ | {{App|OpenJFX EA|Gluon による開発版用の最新 OpenJFX 早期アクセスビルド。|https://openjfx.io/|{{AUR|java-openjfx-ea-bin}}{{Broken package link|package not found}}}} |
||
− | Arch Linux のパッケージのリリースにはパッケージがベースとしているプロプライエタリのバージョンへの言及が含まれていることがありますが、オープンソースプロジェクトには独自のバージョン規則があります: |
||
+ | === 他の実装 === |
||
− | *{{Pkg|jre7-openjdk}}, {{Pkg|jdk7-openjdk}}, {{Pkg|jre7-openjdk-headless}} は [http://icedtea.wildebeest.org/download/source ''IcedTea'' のバージョン] (例: {{ic|2.4.3}}) にあわせて out-of-date になります。Oracle のバージョン (例: {{ic|7.u45_2.4.3-1}} の {{ic|u45}}) は関係ありません。 |
||
+ | |||
− | *{{Pkg|icedtea-web}} は [http://icedtea.wildebeest.org/download/source ''IcedTea Web'' のバージョン] (例: {{ic|1.4.1}}) にあわせて out-of-date になります。''IcedTea'' のバージョンは関係ありません。 |
||
+ | * {{App|Oracle JDK|Oracle の OpenJDK 商用ライセンスビルド。一部のバージョンは手動ダウンロードでしか利用できないことに注意してください。手動ダウンロードでは、OTN 契約に署名し、Oracle アカウントを作成する必要があります。|https://www.oracle.com/java/technologies/downloads/| |
||
+ | : JRE: {{AUR|jre}} {{AUR|jre-lts}} {{AUR|jre11}} {{AUR|jre8}} {{AUR|jre7}} |
||
+ | : JDK: {{AUR|jdk}} {{AUR|jdk-lts}} {{AUR|jdk11}} {{AUR|jdk8}} {{AUR|jdk7}} |
||
+ | }} |
||
+ | * {{App|Eclipse Adoptium/Temurin|Eclipse の JRE/JDK 実装。Hotspot JVM (以前は AdoptOpenJDK) をベースとしています。この JRE は、Eclipse Temurin として知られています。|https://adoptium.net/| {{AUR|jdk-temurin}} {{AUR|jdk17-temurin}} {{AUR|jdk11-temurin}} |
||
+ | }} |
||
+ | * {{App|OpenJ9|IBM によって提供されている、J9 JVM ベースの、Eclipse の JRE/JDK 実装。|https://www.eclipse.org/openj9/| {{AUR|jdk-openj9-bin}} {{AUR|jdk17-openj9-bin}} {{AUR|jdk11-openj9-bin}} {{AUR|jdk8-openj9-bin}} |
||
+ | }} |
||
+ | * {{App|IBM Certified|IBM Semeru Runtime Certified Edition。|https://www.ibm.com/semeru-runtimes/downloads|{{AUR|jdk11-j9-bin}}}} |
||
+ | * {{App|IBM J9|IBM の JRE 実装。OpenJ9 のコードを使用。|https://www.ibm.com/support/pages/java-sdk-downloads|{{AUR|jdk8-j9-bin}} {{AUR|jdk7-j9-bin}} {{AUR|jdk7r1-j9-bin}}}} |
||
+ | * {{App|Azul JDK|Azul の JDK 実装。OpenJDK の Azul Zulu ビルドはオープンソースですが、OpenJDK の Azul Zulu Prime ビルドは開発と評価用では無料の商用製品であることに注意してください。|https://www.azul.com/downloads/| |
||
+ | : Zulu: {{AUR|zulu-8-bin}} {{AUR|zulu-11-bin}} {{AUR|zulu-17-bin}} {{AUR|zulu-21-bin}} |
||
+ | : Zulu Prime: {{AUR|jdk17-zulu-prime-bin}} |
||
+ | }} |
||
+ | |||
+ | {{Note|OpenJDK の 32 ビット版は、64 ビット版のパッケージ名の前に {{ic|bin32-}} を付けることで見つけることができます (例: {{AUR|bin32-jre}})。これらのパッケージは {{AUR|java32-runtime-common}} を使用します。{{AUR|java32-runtime-common}} パッケージは {{Pkg|java-runtime-common}} として機能しますが、ツール名に接尾辞 {{ic|32}} が付きます (例: {{ic|java32}})。これは、32 ビット JDK パッケージによってのみ使用される {{AUR|java32-environment-common}} でも同じです。}} |
||
+ | |||
+ | === 開発ツール === |
||
+ | |||
+ | 統合開発環境については [[アプリケーション一覧/ユーティリティ#統合開発環境]] や ''Java IDE'' サブセクションを見てください。 |
||
+ | |||
+ | リバースエンジニアリングを困難にするには、{{AUR|proguard}} などの難読化ツールを使用できます。 |
||
+ | |||
+ | ==== 逆コンパイラ ==== |
||
+ | |||
+ | * {{App|CFR|Java 9、10、及びそれ以降の最近の機能をサポートしている Java 逆コンパイラ。|https://www.benf.org/other/cfr/|{{Pkg|cfr}}}} |
||
+ | * {{App|Fernflower|[[IntelliJ IDEA]] の一部として開発されている Java 解析逆コンパイラ。|https://github.com/JetBrains/intellij-community/tree/master/plugins/java-decompiler/engine|{{AUR|fernflower-git}}}} |
||
+ | * {{App|Vineflower|Fernflower からフォークされた Java 逆コンパイラ。コードの品質を向上させることを目的としています。[[IntelliJ IDEA]] プラグインとしても利用できます。|https://github.com/Vineflower/vineflower}} |
||
+ | * {{App|Krakatau|Java 逆コンパイラ、アセンブラ、逆アセンブラ。|https://github.com/Storyyeller/Krakatau|{{AUR|krakatau-git}}}} |
||
+ | * {{App|Procyon decompiler|実験的な Java 逆コンパイラ。ILSpy と Mono.Cecil の影響を受けています。|https://bitbucket.org/mstrobel/procyon/wiki/Java%20Decompiler|{{Pkg|procyon-decompiler}}}} |
||
+ | * {{App|Java Decompiler (JD-Core)|人気な Java 逆コンパイラ。GUI (JD-GUI を参照) を提供し、Java 1~10 をサポートしています。|https://java-decompiler.github.io/|{{AUR|jd-core-java}}}} |
||
+ | * {{App|Jadx|Android DEX から Java に逆コンパイルします。オプションの GUI 有り (Jadx-GUI を参照)。|https://github.com/skylot/jadx|{{Pkg|jadx}}}} |
||
+ | * {{App|[[Wikipedia:JAD (software)|JAD]]|メンテナンスされていない Java 逆コンパイラ (最後のリリースは 2006 年です)。|https://varaneckas.com/jad|{{Pkg|jad}}}} |
||
+ | |||
+ | ==== GUI フロントエンド ==== |
||
+ | |||
+ | * {{App|Bytecode Viewer|Java のリバースエンジニアリングスイート。逆コンパイラ、エディタ、そしてデバッガを含んでいます。CFR/Fernflower/Procyon のフロントエンドです。|https://bytecodeviewer.com|{{AUR|bytecode-viewer}}}} |
||
+ | * {{App|Recaf|使いやすいモダンな Java バイトコードエディタ。Java プログラムの複雑さを抽象化します。CFR/Fernflower/Procyon のフロントエンドです。|https://www.coley.software/Recaf/|{{AUR|recaf-bin}}}} |
||
+ | * {{App|Java Decompiler (JD-GUI)|人気な Java 逆コンパイラ。GUI を提供し、Java 1~10 をサポートしています。JD-Core のフロントエンドです。|https://java-decompiler.github.io/|{{AUR|jd-gui}}}} |
||
+ | * {{App|Jadx-GUI|Android APK DEX から Java に逆コンパイルします。オプションの GUI 有り。Jadx のフロントエンドです。|https://github.com/skylot/jadx|{{Pkg|jadx}}}} |
||
+ | * {{App|Luyten|オープンソースの Java 逆コンパイラ GUI。Procyon のフロントエンドです。|https://github.com/deathmarine/Luyten|{{AUR|luyten}}}} |
||
== JVM の切り替え == |
== JVM の切り替え == |
||
− | ヘルパースクリプト {{Ic|archlinux-java}} を |
+ | ヘルパースクリプト {{Ic|archlinux-java}} ({{Pkg|java-runtime-common}} パッケージ) は、以下のような機能を提供します: |
archlinux-java <COMMAND> |
archlinux-java <COMMAND> |
||
COMMAND: |
COMMAND: |
||
+ | status インストールされている Java 環境と有効になっている環境を表示 |
||
− | status List installed Java environments and enabled one |
||
+ | get デフォルトに設定されている Java 環境を返す |
||
− | get Return the short name of the Java environment set as default |
||
− | set <JAVA_ENV> |
+ | set <JAVA_ENV> <JAVA_ENV> をデフォルトに設定 |
− | unset |
+ | unset デフォルトの Java 環境の設定を解除 |
+ | fix 不正な Java 環境の設定を修正 |
||
− | fix Fix an invalid/broken default Java environment configuration |
||
=== インストールされている Java 互換環境を表示 === |
=== インストールされている Java 互換環境を表示 === |
||
106行目: | 135行目: | ||
例: |
例: |
||
+ | {{hc |
||
− | $ archlinux-java status |
||
+ | |$ archlinux-java status |
||
− | Available Java environments: |
||
+ | |Available Java environments: |
||
− | java-7-openjdk (default) |
||
+ | java-11-openjdk (default) |
||
java-8-openjdk/jre |
java-8-openjdk/jre |
||
+ | }} |
||
− | ''(default)'' は {{ |
+ | ''(default)'' は {{ic|java-11-openjdk}} がデフォルトに設定されていることを示しています。{{ic|java}} やその他のバイナリの呼び出しはこの Java インストールに基づきます。また、上の出力では OpenJDK 8 の ''JRE'' しかインストールされていないことに注意してください。 |
=== デフォルトの Java 環境を変更 === |
=== デフォルトの Java 環境を変更 === |
||
121行目: | 152行目: | ||
# archlinux-java set java-8-openjdk/jre |
# archlinux-java set java-8-openjdk/jre |
||
+ | {{Tip|利用可能な {{ic|<JAVA_ENV_NAME>}} 名を各にするには、{{ic|archlinux-java status}} を使ってください。}} |
||
− | {{Ic|archlinux-java}} では存在しない Java 環境は設定できません。上の例では、{{pkg|jre8-openjdk}} はインストールされていますが {{pkg|jdk8-openjdk}} はインストール'''されていない'''ため {{Ic|java-8-openjdk}} を設定しようとしても失敗します: |
||
+ | {{ic|archlinux-java}} は、存在しない Java 環境を設定することはできません。前の例では、{{Pkg|jre8-openjdk}} はインストールされていますが {{Pkg|jdk8-openjdk}} はインストール'''されていない'''ため、{{ic|java-8-openjdk}} を設定しようとしても失敗します: |
||
− | # archlinux-java set java-8-openjdk |
||
+ | |||
− | '/usr/lib/jvm/java-8-openjdk' is not a valid Java environment path |
||
+ | {{hc|# archlinux-java set java-8-openjdk| |
||
+ | '/usr/lib/jvm/java-8-openjdk' is not a valid Java environment path |
||
+ | }} |
||
=== デフォルトの Java 環境の設定を解除 === |
=== デフォルトの Java 環境の設定を解除 === |
||
− | パッケージが設定を管理するため |
+ | パッケージが設定を管理するため、Java 環境の設定を解除する必要はないはずです。それでも設定を解除したいときは、{{ic|unset}} コマンドを使って下さい: |
# archlinux-java unset |
# archlinux-java unset |
||
134行目: | 168行目: | ||
=== デフォルトの Java 環境を修正 === |
=== デフォルトの Java 環境を修正 === |
||
− | 存在しない Java 環境のリンクが設定されている場合、{{ |
+ | 存在しない Java 環境のリンクが設定されている場合、{{ic|archlinux-java fix}} コマンドを呼び出すとリンクの修正が行われます。デフォルトの Java 環境が設定されていないときは、インストールされている Java 環境を探して設定を行います (ここでは、公式でサポートされているパッケージ "OpenJDK 8" がまず初めに使われます。他のインストール環境はその後です): |
# archlinux-java fix |
# archlinux-java fix |
||
140行目: | 174行目: | ||
=== デフォルトでないバージョンの Java を使ってアプリケーションを起動 === |
=== デフォルトでないバージョンの Java を使ってアプリケーションを起動 === |
||
− | デフォルトのバージョン以外の Java を使ってアプリケーションを起動したい場合 (例えば |
+ | デフォルトのバージョン以外の Java を使ってアプリケーションを起動したい場合 (例えばバージョン 18 と 11 の両方がインストールされている場合)、bash スクリプトでアプリケーションをラッピングして Java のデフォルトの PATH を変更することができます。例えば、デフォルトが java 18 で、java 11 を使いたい場合: |
− | #!/bin/sh |
+ | #!/bin/sh |
− | export PATH=/usr/lib/jvm/java- |
+ | export PATH="/usr/lib/jvm/java-11-openjdk/bin/:$PATH" |
− | exec /path/to/application |
+ | exec /path/to/application "$@" |
+ | [[Systemd]] サービスの場合、[[ドロップインファイル]] で {{ic|JAVA_HOME}} を環境変数に追加することで可能です: |
||
− | == {{Ic|archlinux-java}} をサポートするのに必要なパッケージの条件 == |
||
− | このセクションは [[AUR]] に新しい JVM のパッケージを投稿し、Arch Linux の JVM の扱いかたにあわせて {{Ic|archlinux-java}} を使用したいパッケージ作成者を対象にしています。パッケージは以下の条件を満たす必要があります: |
||
+ | {{hc|/etc/systemd/system/''unit''.d/override.conf|2= |
||
− | * 全てのファイルは {{Ic|/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME} }} 以下に配置 |
||
+ | [Service] |
||
− | * 該当するパッケージに [https://www.archlinux.org/packages/extra/any/java-runtime-common/files/ java-runtime-common] や [https://www.archlinux.org/packages/extra/any/java-environment-common/files/ java-environment-common] に入っているリンクの実行可能ファイルがあること |
||
+ | Environment=JAVA_HOME=/usr/lib/jvm/java-11-openjdk |
||
− | * リンクが [https://www.archlinux.org/packages/extra/any/java-runtime-common/files/ java-runtime-common] や [https://www.archlinux.org/packages/extra/any/java-environment-common/files/ java-environment-common] にない場合にのみ、{{Ic|/usr/bin}} から実行可能ファイルへのリンク |
||
+ | }} |
||
− | * man ページの末尾に {{Ic|-${VENDOR_NAME}${JAVA_MAJOR_VERSION} }} をつけて衝突しないようにする ([https://www.archlinux.org/packages/extra/x86_64/jre8-openjdk/files/ jre8-openjdk のファイルリスト]を見れば {{Ic|-openjdk8}} を付ける man ページがわかります) |
||
− | * 他の JDK や {{Ic|java-runtime}}, {{Ic|java-runtime-headless}}, {{Ic|java-environment}} の [[PKGBUILD#conflicts|conflicts]] や [[PKGBUILD#replaces|replaces]] は宣言しない |
||
− | * ''install 関数''で {{Ic|archlinux-java}} スクリプトを使って'''他の Java 環境が設定されていない場合に''' Java 環境をデフォルトに設定 (強制的にデフォルトとしてインストールしてはいけません)。サンプルは[https://projects.archlinux.org/svntogit/packages.git/tree/trunk?h=packages/java7-openjdk 公式にサポートされている Java 環境のパッケージのソース]を参照。 |
||
+ | == archlinux-java をサポートするために必要なパッケージの前提条件 == |
||
− | 他の注意事項: |
||
− | * Java 環境が必要なパッケージでベンダーを問わない場合は通常通りに {{Ic|java-runtime}}, {{Ic|java-runtime-headless}} または {{Ic|java-environment}} を依存パッケージとして宣言してください |
||
− | * '''特定の Java ベンダー'''が必要なパッケージは適当なパッケージを依存パッケージとして宣言してください |
||
− | * OpenJDK パッケージは {{Ic|1=provides="java-runtime-openjdk=${pkgver}"}} などを宣言しています。このためサードパーティのパッケージはバージョンを指定せずに OpenJDK を依存パッケージとして宣言することができます |
||
+ | {{Note|以下の情報は32ビットの Java パッケージである {{ic|archlinux32-java}} にも同じく当てはまります。必要に応じて、パッケージや実行ファイルの名前には {{ic|32}} を含めてください。}} |
||
− | == AUR のサポートされていない JVM == |
||
+ | このセクションでは、代替 JVM 用のパッケージを [[AUR]] で提供したいパッケージ製作者が、パッケージを Arch Linux の JVM スキームと統合できる (つまり、{{ic|archlinux-java}} と互換性を持たせる) ようにするための説明を行います。これに関しては、パッケージ制作者は以下のことを行う必要があります: |
||
− | {{Warning|[[AUR]] のパッケージは {{Ic|archlinux-java}} をサポートしていたりしていなかったりします。}} |
||
+ | * 全てのファイルは {{ic|/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME} }} 以下に配置すること |
||
− | === Java SE === |
||
+ | * {{pkg|java-runtime-common}} と {{pkg|java-environment-common}} が提供するシンボリックリンクに対応する全ての実行ファイルが、該当するパッケージにおいて利用可能であること。(訳注: 例えば、{{Pkg|java-runtime-common}} は {{ic|/usr/bin/java}} シンボリックリンクを提供していますが、あなたの作成したパッケージにもこれに対応する実行ファイルが含まれていなければなりません。その他のシンボリックリンクにおいても同様です。) |
||
− | Oracle による JRE と JDK の実装は [[Arch User Repository|AUR]] から利用できます: {{AUR|jre}}, {{AUR|server-jre}}, {{AUR|jdk}}。 |
||
+ | * シンボリックリンクがまだ [{{pkg|java-runtime-common}} と {{pkg|java-environment-common}} に存在しない場合にのみ、{{ic|/usr/bin}} から実行ファイルへのシンボリックリンクを同梱すること。 |
||
+ | * man ページの末尾に {{ic|-${VENDOR_NAME}${JAVA_MAJOR_VERSION} }} を付けて、衝突しないようにすること ({{pkg|jre8-openjdk}} のファイルリストを見れば {{ic|-openjdk8}} を付ける man ページがわかります) |
||
+ | * 他の JDK、{{ic|java-runtime}}、{{ic|java-runtime-headless}}、{{ic|java-environment}} を [[PKGBUILD#conflicts|conflicts]] や [[PKGBUILD#replaces|replaces]] として宣言しないこと。 |
||
+ | * ''install 関数''で {{ic|archlinux-java}} スクリプトを使って、'''他の有効な Java 環境が設定されていない場合に''' 自身の Java 環境をデフォルトに設定すること (つまり、パッケージは'''強制的に'''デフォルトとして設定するべきでは'''ありません''')。サンプルは[https://github.com/archlinux/svntogit-packages/blob/packages/java8-openjdk/trunk 公式にサポートされている Java 環境のパッケージのソース]を参照。 |
||
+ | 他の注意事項: |
||
− | ==== Java SE 6/7 ==== |
||
− | [[Arch User Repository|AUR]] には旧バージョンである {{AUR|jre6}}/{{AUR|jre6-compat}}/{{AUR|jre7}} と {{AUR|jdk6}}/{{AUR|jdk6-compat}}/{{AUR|jdk7}} が含まれています。 |
||
+ | * '''任意の''' Java 環境を必要とするパッケージは、通常通り {{ic|java-runtime}}、{{ic|java-runtime-headless}}、{{ic|java-environment}} のどれかを依存関係として宣言すること。 |
||
− | === Oracle JRockit === |
||
+ | * '''特定の Java ベンダ''' を必要とするパッケージは、それに対応するパッケージを依存関係として宣言すること。 |
||
− | [http://www.oracle.com/technetwork/middleware/jrockit/overview/index.html JRockit] は Oracle による Java の JIT バージョンであり、[[Arch User Repository|AUR]] の {{AUR|jrockit}} からインストールできます。 |
||
+ | * OpenJDK パッケージでは、{{ic|1=provides="java-runtime-openjdk=${pkgver}"}} などが宣言されるようになっています。これにより、サードパーティのパッケージではバージョンを指定せずに OpenJDK を依存関係として宣言できるようになっています。 |
||
− | |||
− | === VMkit === |
||
− | [http://vmkit.llvm.org/index.html VMkit] は JIT 仮想マシンのための LLVM ベースのフレームワークです。J3 は VMkit を動作させる JVM です。ウェブページはここにあります: [http://vmkit.llvm.org/get_started.html vmkit]。J3 は GNU classpath ライブラリに依存していますが、Apache のクラスパスライブラリを使うことも可能です。 |
||
− | |||
− | === Parrot VM === |
||
− | [http://www.parrot.org/ Parrot] は VM であり、異なる2つの方法によって実験的に [http://trac.parrot.org/parrot/wiki/Languages Java をサポート] しています: [http://code.google.com/p/parrot-jvm/ Java VM バイトコード翻訳機] もしくは [https://github.com/chrisdolan/perk Parrot VM のための Java コンパイラ]。{{Pkg|parrot}} は[[公式リポジトリ]]からインストールでき、[[Arch User Repository|AUR]] には {{AUR|parrot-git}} があります。 |
||
== トラブルシューティング == |
== トラブルシューティング == |
||
+ | |||
=== MySQL === |
=== MySQL === |
||
+ | |||
− | JDBC ドライバーは URL のポートを使ってデータベースへの接続を確立するため、同じホストで動作していたとしても"リモート"とされます (すなわち MySQL はデフォルト設定のようにポートを開きません)。そのため、JDBC と MySQL を使うには MySQL のリモートアクセスを有効にする必要があります。[[MySQL#リモートアクセスを有効にする|MySQL の記事]]の指示に従って下さい。 |
||
+ | JDBC ドライバーは URL のポートを使ってデータベースへの接続を確立するため、同じホストで動作していたとしても"リモート"とされます (すなわち MySQL はデフォルト設定のようにポートを開きません)。そのため、JDBC と MySQL を使うには MySQL のリモートアクセスを有効にする必要があります。[[MariaDB#リモートアクセスを有効にする]] の指示に従って下さい。 |
||
+ | |||
+ | === IntelliJ IDEA === |
||
+ | |||
+ | IntelliJ IDEA がシステムの JAVA SDK のパスと共に {{ic|The selected directory is not a valid home for JDK}} と出力する場合、他の JDK パッケージをインストールして、そのパッケージを IDEA の JDK として選択する必要があるかもしれません。 |
||
=== 他のウィンドウマネージャになりすます === |
=== 他のウィンドウマネージャになりすます === |
||
− | [http://tools.suckless.org/wmname suckless.org] の {{pkg|wmname}} を使うことで JVM に他のウィンドウマネージャを動かしていると信じこませることが可能です。これによって [[Awesome]] や [[Dwm]] などのウィンドウマネージャで起こる Java の GUI のレンダリング問題が解決する可能性があります。 |
||
+ | [https://tools.suckless.org/x/wmname suckless.org] の {{Pkg|wmname}} を使うことで、他のウィンドウマネージャを動かしていると JVM に信じ込ませることができます。これによって、[[Awesome]] や [[Dwm]]、[[Ratpoison]] のようなウィンドウマネージャで発生する Java の GUI レンダリング問題を解決できる場合があります。これがうまく行く理由は、JVM には[[Wikipedia:ja:リペアレンティング型ウィンドウマネージャ|リペアレンティング型]]でない既知のウィンドウマネージャのハードコードされたリストが含まれているからです。皮肉なことに、一部のユーザは、[[wikipedia:Project_Looking_Glass|Sun によって Java で記述された]]リペアレンティング型でないウィンドウマネージャである {{ic|LG3D}} になりすますことを好みます。"compiz" や "Metacity"、"LG3D" に設定してみてください: |
||
− | $ wmname LG3D |
||
+ | |||
+ | $ wmname ''ウィンドウマネージャ名'' |
||
− | + | wmname コマンドを実行した後、問題が発生しているアプリケーションを再起動する必要があります。 |
|
+ | あるいは、[https://github.com/zheludkovm/JavaMatePatch javaagent JavaMatePatch] を使うこともできます。これは、[[MATE]] においてウィンドウマネージャ名を設定し、Java Swing アプリがフルスクリーン時に不適切な挙動を行うバグを解決するために作成されました。使用するには、{{ic|1=-javaagent:JavaMatePatch-1.0.0-SNAPSHOT.jar=''ウィンドウマネージャ名''}} を java オプションに追加してください。 |
||
− | これが機能するのは JVM にはハードコードされた既知の、ノンリペアレントウィンドウマネージャのリストが含まれているためです。最大の皮肉として、[[wikipedia:Project_Looking_Glass|Sun によって Java で書かれた]]ノンリペアレントウィンドウマネージャである {{ic|LG3D}} になりすますことを好むユーザーもいます。 |
||
=== フォントが読みにくい === |
=== フォントが読みにくい === |
||
− | 下の [[#フォントレンダリングを改善する]] で書かれている方法でも、フォントによっては読みやすくならないことがあります。このようなときは、使用している MS フォントを変えてみて下さい。AUR から {{AUR|ttf-ms-fonts}} をインストールしてください。 |
||
+ | 下の [[#フォントレンダリングを改善する]] で書かれている方法でも、フォントによっては読みやすくならないことがあります。このようなときは、使用している MS フォントを変えてみて下さい。{{AUR|ttf-ms-fonts}} パッケージをインストールしてください。 |
||
− | === 特定のアプリケーションでテキストが表示されない === |
||
− | 特定のアプリケーションでテキストが完全に表示されない場合は {{Bug|40871}} で提案されているように [[#Tips and tricks]] のオプションを使うと直るかもしれません。 |
||
+ | === 一部のアプリケーションでテキストが表示されない === |
||
− | === Too many levels of symbolic links === |
||
+ | 一部のアプリケーションでテキストが全く表示されない場合は {{Bug|40871}} で提案されているように [[#ヒントとテクニック]] のオプションを使うと直るかもしれません。 |
||
− | 以下のようなエラーが表示される場合: |
||
+ | === 灰色のウィンドウ、ウィンドウマネージャでアプリがリサイズされない、メニューがすぐに閉じる === |
||
− | /usr/bin/java: line 2: /usr/lib/jvm/default/bin/java: Too many levels of symbolic links |
||
− | /usr/bin/java: line 2: exec: /usr/lib/jvm/default/bin/java: cannot execute: Too many levels of symbolic links |
||
+ | 標準の Java GUI ツールキットには、「リペアレンティング型でない」ウィンドウマネージャのハードコードされたリストがあります。そのリストに無いウィンドウマネージャを使用すると、一部の Java アプリケーションで問題が発生する可能性があります。最も一般的な問題の1つが、Java アプリケーションが GUI をレンダリングせずにのっぺりとした灰色のボックスとして表示される「灰色のウィンドウ」問題です。クリックでメニューを開いてもすぐに閉じてしまう問題も発生することがあります。 |
||
− | [[#デフォルトの Java 環境を修正|デフォルトの Java 環境を修正]]することで問題が解決するはずです。[https://bbs.archlinux.org/viewtopic.php?pid=1453803] も見て下さい。 |
||
+ | 解決に役立つ方法がいくつか存在します: |
||
− | == Tips and tricks == |
||
− | {{Note|このセクションで提案されていることは、インストールされている (外部の) Java ランタイムを明示的に使用する全てのアプリケーションに適用されます。ただし独自の (内部の) ランタイムを持っていたり GUI やフォントレンダリングに独自の手法を使っているアプリケーションも存在するため、下に書かれていることが全て機能するとは保証できません。}} |
||
+ | * [[#他のウィンドウマネージャになりすます]] を参照してください。 |
||
− | Java アプリケーションのほとんどは Java ランタイムの前に変数を設定することで挙動をコントロールすることができます。[https://bbs.archlinux.org/viewtopic.php?id=72892 フォーラムの投稿]より、変数を設定するには {{Ic|~/.bashrc}} (もしくは全てのユーザーに適用するには {{Ic|/etc/profile.d/jre.sh}}) に次の行を追加してください: |
||
+ | * {{Pkg|jre8-openjdk}} の場合、{{ic|1=_JAVA_AWT_WM_NONREPARENTING=1}} [[環境変数]]を設定してください。 |
||
+ | * その後のバージョンでは、{{ic|1=AWT_TOOLKIT=MToolkit}} [[環境変数]]を設定してください。 |
||
+ | * [[xmonad]] の場合、[https://wiki.haskell.org/Xmonad/Frequently_asked_questions#Using_SetWMName SetWMName] を使用してください。ただし、{{ic|XMonad.Hooks.EwmhDesktops}} を使うと効果がキャンセルされてしまうことがあります。その場合、{{ic|>> setWMName "LG3D"}} を {{ic|LogHook}} に追加すると解決できる場合があります。 |
||
+ | 詳細は [https://wiki.haskell.org/Xmonad/Frequently_asked_questions#Problems_with_Java_applications.2C_Applet_java_console] を参照してください。 |
||
− | export _JAVA_OPTIONS="-D'''<option 1>''' -D'''<option 2>'''..." |
||
+ | |||
+ | === JavaFX アプリケーションのデバッグ時にシステムがフリーズする === |
||
+ | |||
+ | JavaFX アプリケーションをデバッグする際にシステムがフリーズする場合、JVM のオプション {{ic|1=-Dsun.awt.disablegrab=true}} を使ってみてください。 |
||
+ | |||
+ | https://bugs.java.com/bugdatabase/view_bug?bug_id=6714678 を参照。 |
||
+ | |||
+ | === JavaFX の MediaPlayer コンストラクタが例外を投げる === |
||
+ | |||
+ | JavaFX のサウンドモジュールから MediaPlayer クラスのインスタンスを作成しようとしたときに以下の例外が発生することがあります (Oracle JDK と OpenJDK の両方で発生): |
||
+ | |||
+ | ... (i.e. FXMLLoader construction exceptions) ... |
||
+ | Caused by: MediaException: UNKNOWN : com.sun.media.jfxmedia.MediaException: Could not create player! : com.sun.media.jfxmedia.MediaException: Could not create player! |
||
+ | at javafx.scene.media.MediaException.exceptionToMediaException(MediaException.java:146) |
||
+ | at javafx.scene.media.MediaPlayer.init(MediaPlayer.java:511) |
||
+ | at javafx.scene.media.MediaPlayer.<init>(MediaPlayer.java:414) |
||
+ | at <constructor call> |
||
+ | ... |
||
+ | |||
+ | 原因は JavaFX が Arch Linux のリポジトリに含まれている新しい {{Pkg|ffmpeg}} と互換性がないためです。 |
||
+ | |||
+ | 解決方法は {{AUR|ffmpeg-compat-55}} をインストールすることです。または、先のバージョンがビルドに失敗する場合は、{{AUR|ffmpeg-compat-57}} をインストールするとうまく行くかもしれません。 |
||
+ | |||
+ | 参照: https://www.reddit.com/r/archlinux/comments/70o8o6/using_a_javafx_mediaplayer_in_arch/ |
||
+ | |||
+ | === Java アプリケーションで外部リンクを開けない === |
||
+ | |||
+ | Java アプリケーションからウェブブラウザなどのリンクを開けない場合、{{Pkg|gvfs}} をインストールしてください。Desktop.Action.BROWSE メソッドが必要とします。[https://bugs.launchpad.net/ubuntu/+source/openjdk-8/+bug/1574879/comments/2] を参照。 |
||
+ | |||
+ | === QuantumRenderer の初期化でエラー: no suitable pipeline found === |
||
+ | |||
+ | 考えられる問題と解決策: |
||
+ | |||
+ | * GTK2 が無い。{{Pkg|gtk2}} をインストールしてください。 |
||
+ | * OpenJFX が無い。{{AUR|java-openjfx}} をインストールしてください。 |
||
+ | |||
+ | == ヒントとテクニック == |
||
+ | |||
+ | {{Note|このセクションで提案されていることは、インストールされている (外部の) Java ランタイムを明示的に使用する全てのアプリケーションに適用できます。ただし独自の (内部の) ランタイムを持っていたり GUI やフォントレンダリングに独自の手法を使っているアプリケーションも存在するため、下に書かれていることが全て機能するとは保証できません。}} |
||
+ | |||
+ | Java アプリケーションのほとんどは Java ランタイムの前に変数を設定することで挙動をコントロールすることができます。[https://bbs.archlinux.org/viewtopic.php?id=72892 フォーラムの投稿]より、変数を設定するには {{Ic|~/.bashrc}} (もしくは全てのユーザーに適用するには {{ic|/etc/profile.d/jre.sh}}) に次の行を追加してください: |
||
+ | |||
+ | export JDK_JAVA_OPTIONS="-D'''<option 1>''' -D'''<option 2>'''..." |
||
例えば、システムのアンチエイリアスがされたフォントを使用して swing に GTK のルックアンドフィールを使わせるには: |
例えば、システムのアンチエイリアスがされたフォントを使用して swing に GTK のルックアンドフィールを使わせるには: |
||
− | export |
+ | export JDK_JAVA_OPTIONS='-Dawt.useSystemAAFontSettings=on -Dswing.aatext=true -Dswing.defaultlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel' |
+ | |||
+ | このような変数は3つ存在しており、以下の表で後に説明されるオプションが優先されます。 |
||
+ | |||
+ | {| class="wikitable" |
||
+ | |- |
||
+ | | JAVA_TOOL_OPTIONS |
||
+ | | javac や jshell といったアプリケーションとツールに影響します。 |
||
+ | |- |
||
+ | | JDK_JAVA_OPTIONS |
||
+ | | アプリケーション (java コマンドで実行されるアプリケーション全て) に影響します。Java 9 が必要。 |
||
+ | |- |
||
+ | | (コマンドラインオプション) |
||
+ | | "クラス名" の引数の前で指定される引数は Java オプションです。 |
||
+ | |- |
||
+ | | _JAVA_OPTIONS |
||
+ | | 古い方法。アプリケーションとツールに影響します。 |
||
+ | |} |
||
=== フォントレンダリングを改善する === |
=== フォントレンダリングを改善する === |
||
− | クローズドソースとオープンソースの Java 実装のどちらもがフォントのアンチエイリアスを不適当に実装していることが知られています。次のオプションを使うことでこれを修正することが可能です: {{Ic|1=awt.useSystemAAFontSettings=on}}, {{Ic|1=swing.aatext=true}} |
||
+ | クローズドソースとオープンソースの Java 実装のどちらもがフォントのアンチエイリアスを不適当に実装していることが知られています。次のオプションを使うことでこれを修正することが可能です: {{ic|1=-Dawt.useSystemAAFontSettings=on}}, {{ic|1=-Dswing.aatext=true}} |
||
− | 詳しい情報は [[Java ランタイム環境のフォント]]を見て下さい。 |
||
+ | |||
+ | 詳しい情報は [[Java 実行環境のフォント]]を見てください。 |
||
+ | |||
+ | === コマンドラインの 'Picked up JDK_JAVA_OPTIONS' メッセージを消す === |
||
+ | |||
+ | JDK_JAVA_OPTIONS 環境変数を設定すると java (openjdk) から標準エラー出力に次のようなメッセージが書き出されます: 'Picked up JDK_JAVA_OPTIONS=...'。ターミナルにこのメッセージを表示しないようにするには、シェルのスタートアップファイルから環境変数を消去して、以下のように java のエイリアスを作成してコマンドライン引数を使ってオプションを指定するようにしてください: |
||
+ | |||
+ | SILENT_JAVA_OPTIONS="$JDK_JAVA_OPTIONS" |
||
+ | unset JDK_JAVA_OPTIONS |
||
+ | alias java='java "$SILENT_JAVA_OPTIONS"' |
||
+ | |||
+ | インタラクティブでないシェル (Java プログラムのランチャースクリプトなど) は、(通常) {{ic|~/.bashrc}} を読み込みません。ですが、export された変数を親プロセスから継承します ({{ic|~/.bash_profile}} を読み込むログインシェルからどこかの時点でその変数を継承します)。 |
||
+ | そうした場合、ファイルが読み取られるのを防ぐために、{{ic|~/.bashrc}} の先頭に文を置いているのが一般的です。そのようにして、変数がデスクトップメニューから起動されたプログラムに渡され、メッセージが邪魔をするインタラクティブシェルの場合は alias が代わりに使用されます (スクリプトでは alias は使用できません)。 |
||
=== GTK のルックアンドフィール === |
=== GTK のルックアンドフィール === |
||
− | Java プログラムの見た目が酷い場合、swing コンポーネントのデフォルトのルックアンドフィールを設定することができます: {{Ic|1=swing.defaultlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel}}. |
||
− | + | Java プログラムの見た目が酷い場合、swing コンポーネントのデフォルトのルックアンドフィールを設定することができます: |
|
+ | |||
+ | swing.defaultlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel |
||
+ | |||
+ | 頑固な Java プログラムはクロスプラットフォームの Metal ルックアンドフィールを使用し続けることがあります。そのような場合には以下のプロパティを設定することで GTK のルックアンドフィールを使うように強制することが可能です: |
||
+ | |||
+ | swing.crossplatformlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel |
||
+ | |||
+ | ==== GTK3 のサポート ==== |
||
+ | |||
+ | バージョン 9 より前の Java では、GTK のルックアンドフィールが GTK2 に対してリンクされていますが、新しいデスクトップアプリケーションは GTK3 を使用します。GTK バージョン間の非互換性のせいで、GTK3 アプリに GUI の Java プラグインが存在すると、Java の GUI を開いたときにアプリがクラッシュする場合があります。同じプロセスで GTK2 と GTK3 を混ぜることはできません。例えば LibreOffice 5.0 などがこれに該当します。 |
||
+ | |||
+ | GTK ルックアンドフィールは GTK バージョン {{ic|2}}、{{ic|2.2}}、そして {{ic|3}} に対して実行でき、デフォルトは GTK3 です。これは、次のプロパティを設定することで上書きできます: |
||
+ | |||
+ | jdk.gtk.version=2.2 |
||
+ | |||
+ | === HiDPI === |
||
+ | |||
+ | GUI フレームワークによっては、他の方法を使うことで [[HiDPI#Java アプリケーション]] を利用可能にできます。 |
||
+ | |||
+ | === 2D のパフォーマンスの向上 === |
||
+ | |||
+ | OpenGL ベースのハードウェアアクセラレーションパイプラインに切り替えることで 2D の性能が改善します: |
||
+ | |||
+ | export JDK_JAVA_OPTIONS='-Dsun.java2d.opengl=true' |
||
+ | |||
+ | {{Note|このオプションを有効にすると JetBrains IDE などのソフトウェアの UI がおかしくなって、ウィンドウやポップアップ、ツールバーが一部しか表示されなくなることがあります。}} |
||
+ | == 参照 == |
||
− | === リペアレントしないウィンドウマネージャ === |
||
+ | * [https://math.hws.edu/javanotes8/ Introduction to Programming Using Java] |
||
− | リペアレントしないウィンドウマネージャを使用する場合は {{Ic|.xinitrc}} で以下の環境変数を設定してください: |
||
+ | * [https://www.w3schools.com/java/default.asp W3Schools による Java チュートリアル] |
||
+ | {{TranslationStatus|Java|2024-02-22|800003}} |
||
− | export _JAVA_AWT_WM_NONREPARENTING=1 |
2024年2月22日 (木) 18:05時点における版
Wikipedia より:
- Java は Sun Microsystems によって開発され1995年に Sun Microsystems の Java プラットフォームのコアコンポーネントとしてリリースされたプログラミング言語です。構文は C および C++ から多くを引き継いでいますが、オブジェクトモデルがシンプルで低水準の機能が削られています。基本的に Java のアプリケーションはコンピュータアーキテクチャに関係なく動く Java 仮想マシン (JVM) で動くバイトコードにコンパイルされます。
Arch Linux は、オープンソースの OpenJDK バージョン 8、11、17、そして 21 を公式にサポートしています。これらの JVM は全てインストールしても衝突せず、ヘルパースクリプト archlinux-java
を使って切り替えることが可能です。他の Java 環境はいくつか AUR からインストールすることができますが、公式のサポートはありません。
目次
- 1 インストール
- 2 JVM の切り替え
- 3 archlinux-java をサポートするために必要なパッケージの前提条件
- 4 トラブルシューティング
- 4.1 MySQL
- 4.2 IntelliJ IDEA
- 4.3 他のウィンドウマネージャになりすます
- 4.4 フォントが読みにくい
- 4.5 一部のアプリケーションでテキストが表示されない
- 4.6 灰色のウィンドウ、ウィンドウマネージャでアプリがリサイズされない、メニューがすぐに閉じる
- 4.7 JavaFX アプリケーションのデバッグ時にシステムがフリーズする
- 4.8 JavaFX の MediaPlayer コンストラクタが例外を投げる
- 4.9 Java アプリケーションで外部リンクを開けない
- 4.10 QuantumRenderer の初期化でエラー: no suitable pipeline found
- 5 ヒントとテクニック
- 6 参照
インストール
2つの 共通 パッケージがそれぞれ依存パッケージとしてインストールされます: java-runtime-common (全ての Java Runtime Environment に共通のファイルが含まれています) と java-environment-common (全ての Java Development Kit に共通のファイルが含まれています) です。提供される環境ファイル /etc/profile.d/jre.sh
は、シンボリックリンクによって参照されている /usr/lib/jvm/default/bin
を指しており、このシンボリックリンクは archlinux-java
ヘルパースクリプトによって設定されます。
これは、/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME}
内のデフォルトの作業 Java 環境や、/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME}/jre
内の Java ランタイムを表示したり指定したりするために使用されます。
Java 環境のほとんどの実行ファイルは、/usr/bin/
内のダイレクトリンクによって提供されます。一方、その他は $PATH
でアクセスできます。/etc/profile.d/jdk.sh
スクリプトは、もはやどのパッケージからも提供されません。
OpenJDK
OpenJDK は、Java Platform, Standard Edition (Java SE) のオープンソースな実装であり、公式リファレンス実装として指定されています。OpenJDK ビルドには、Adoptium (以前は AdoptOpenJDK として知られていました) や Amazon Corretto などの複数のディストリビューターが存在しています。Arch Linux の OpenJDK パッケージは上流の OpenJDK ソースコードからビルドされています。
- ヘッドレス JRE
- 最小限の Java 実行環境 - 非 GUI な Java プログラムを実行するために必要。
- フル JRE
- 完全な Java 実行環境 - Java の GUI プログラムを実行するために必要。
- JDK
- Java Development Kit - Java で開発するために必要。
バージョン 21 より前の OpenJDK では、OpenJDK は JRE に依存しており、JRE は ヘッドレス JRE に依存しています。しかし、OpenJDK 21 では、小さいパッケージはサブセットであるため、それぞれのバージョンは互いに衝突します。つまり、OpenJDK 21 では、JDK は JRE を提供すると同時に JRE と衝突し、JRE はヘッドレス JRE を提供すると同時にヘッドレス JRE と衝突します。
OpenJDK GA — Oracle による最新 OpenJDK 一般公開リリースビルド。
OpenJDK EA — Oracle による開発版用の最新 OpenJDK 早期アクセスビルド。
IcedTea-Web — Java Web Start と非推奨の Java ブラウザプラグイン。
OpenJFX
OpenJFX は、JavaFX のオープンソースな実装です。Oracle JDK を使用している場合は、このパッケージをインストールする必要はありません。このパッケージは、Java のオープンソース実装 (OpenJDK プロジェクト) やその派生版のユーザのみを対象としています。
バージョン | 実行環境及び開発環境 | ドキュメント | ソース |
---|---|---|---|
OpenJFX 21 | java-openjfxAUR | java-openjfx-docAUR | java-openjfx-srcAUR |
OpenJFX 17 | java17-openjfxAUR | java17-openjfx-docAUR | java17-openjfx-srcAUR |
OpenJFX GA — Gluon による最新 OpenJFX 一般公開リリースビルド。
OpenJFX EA — Gluon による開発版用の最新 OpenJFX 早期アクセスビルド。
- https://openjfx.io/ || java-openjfx-ea-binAUR[リンク切れ: package not found]
他の実装
- Oracle JDK — Oracle の OpenJDK 商用ライセンスビルド。一部のバージョンは手動ダウンロードでしか利用できないことに注意してください。手動ダウンロードでは、OTN 契約に署名し、Oracle アカウントを作成する必要があります。
- https://www.oracle.com/java/technologies/downloads/ ||
- JRE: jreAUR jre-ltsAUR jre11AUR jre8AUR jre7AUR
- JDK: jdkAUR jdk-ltsAUR jdk11AUR jdk8AUR jdk7AUR
- Eclipse Adoptium/Temurin — Eclipse の JRE/JDK 実装。Hotspot JVM (以前は AdoptOpenJDK) をベースとしています。この JRE は、Eclipse Temurin として知られています。
- https://adoptium.net/ || jdk-temurinAUR jdk17-temurinAUR jdk11-temurinAUR
- OpenJ9 — IBM によって提供されている、J9 JVM ベースの、Eclipse の JRE/JDK 実装。
- https://www.eclipse.org/openj9/ || jdk-openj9-binAUR jdk17-openj9-binAUR jdk11-openj9-binAUR jdk8-openj9-binAUR
- IBM Certified — IBM Semeru Runtime Certified Edition。
- IBM J9 — IBM の JRE 実装。OpenJ9 のコードを使用。
- https://www.ibm.com/support/pages/java-sdk-downloads || jdk8-j9-binAUR jdk7-j9-binAUR jdk7r1-j9-binAUR
- Azul JDK — Azul の JDK 実装。OpenJDK の Azul Zulu ビルドはオープンソースですが、OpenJDK の Azul Zulu Prime ビルドは開発と評価用では無料の商用製品であることに注意してください。
- https://www.azul.com/downloads/ ||
- Zulu: zulu-8-binAUR zulu-11-binAUR zulu-17-binAUR zulu-21-binAUR
- Zulu Prime: jdk17-zulu-prime-binAUR
開発ツール
統合開発環境については アプリケーション一覧/ユーティリティ#統合開発環境 や Java IDE サブセクションを見てください。
リバースエンジニアリングを困難にするには、proguardAUR などの難読化ツールを使用できます。
逆コンパイラ
- CFR — Java 9、10、及びそれ以降の最近の機能をサポートしている Java 逆コンパイラ。
- Fernflower — IntelliJ IDEA の一部として開発されている Java 解析逆コンパイラ。
- https://github.com/JetBrains/intellij-community/tree/master/plugins/java-decompiler/engine || fernflower-gitAUR
- Vineflower — Fernflower からフォークされた Java 逆コンパイラ。コードの品質を向上させることを目的としています。IntelliJ IDEA プラグインとしても利用できます。
- https://github.com/Vineflower/vineflower || パッケージが存在しないか AUR で検索
- Krakatau — Java 逆コンパイラ、アセンブラ、逆アセンブラ。
- Procyon decompiler — 実験的な Java 逆コンパイラ。ILSpy と Mono.Cecil の影響を受けています。
- Java Decompiler (JD-Core) — 人気な Java 逆コンパイラ。GUI (JD-GUI を参照) を提供し、Java 1~10 をサポートしています。
- Jadx — Android DEX から Java に逆コンパイルします。オプションの GUI 有り (Jadx-GUI を参照)。
- JAD — メンテナンスされていない Java 逆コンパイラ (最後のリリースは 2006 年です)。
GUI フロントエンド
- Bytecode Viewer — Java のリバースエンジニアリングスイート。逆コンパイラ、エディタ、そしてデバッガを含んでいます。CFR/Fernflower/Procyon のフロントエンドです。
- Recaf — 使いやすいモダンな Java バイトコードエディタ。Java プログラムの複雑さを抽象化します。CFR/Fernflower/Procyon のフロントエンドです。
- Java Decompiler (JD-GUI) — 人気な Java 逆コンパイラ。GUI を提供し、Java 1~10 をサポートしています。JD-Core のフロントエンドです。
- Jadx-GUI — Android APK DEX から Java に逆コンパイルします。オプションの GUI 有り。Jadx のフロントエンドです。
- Luyten — オープンソースの Java 逆コンパイラ GUI。Procyon のフロントエンドです。
JVM の切り替え
ヘルパースクリプト archlinux-java
(java-runtime-common パッケージ) は、以下のような機能を提供します:
archlinux-java <COMMAND> COMMAND: status インストールされている Java 環境と有効になっている環境を表示 get デフォルトに設定されている Java 環境を返す set <JAVA_ENV> <JAVA_ENV> をデフォルトに設定 unset デフォルトの Java 環境の設定を解除 fix 不正な Java 環境の設定を修正
インストールされている Java 互換環境を表示
$ archlinux-java status
例:
$ archlinux-java status
Available Java environments: java-11-openjdk (default) java-8-openjdk/jre
(default) は java-11-openjdk
がデフォルトに設定されていることを示しています。java
やその他のバイナリの呼び出しはこの Java インストールに基づきます。また、上の出力では OpenJDK 8 の JRE しかインストールされていないことに注意してください。
デフォルトの Java 環境を変更
# archlinux-java set <JAVA_ENV_NAME>
例:
# archlinux-java set java-8-openjdk/jre
archlinux-java
は、存在しない Java 環境を設定することはできません。前の例では、jre8-openjdk はインストールされていますが jdk8-openjdk はインストールされていないため、java-8-openjdk
を設定しようとしても失敗します:
# archlinux-java set java-8-openjdk
'/usr/lib/jvm/java-8-openjdk' is not a valid Java environment path
デフォルトの Java 環境の設定を解除
パッケージが設定を管理するため、Java 環境の設定を解除する必要はないはずです。それでも設定を解除したいときは、unset
コマンドを使って下さい:
# archlinux-java unset
デフォルトの Java 環境を修正
存在しない Java 環境のリンクが設定されている場合、archlinux-java fix
コマンドを呼び出すとリンクの修正が行われます。デフォルトの Java 環境が設定されていないときは、インストールされている Java 環境を探して設定を行います (ここでは、公式でサポートされているパッケージ "OpenJDK 8" がまず初めに使われます。他のインストール環境はその後です):
# archlinux-java fix
デフォルトでないバージョンの Java を使ってアプリケーションを起動
デフォルトのバージョン以外の Java を使ってアプリケーションを起動したい場合 (例えばバージョン 18 と 11 の両方がインストールされている場合)、bash スクリプトでアプリケーションをラッピングして Java のデフォルトの PATH を変更することができます。例えば、デフォルトが java 18 で、java 11 を使いたい場合:
#!/bin/sh export PATH="/usr/lib/jvm/java-11-openjdk/bin/:$PATH" exec /path/to/application "$@"
Systemd サービスの場合、ドロップインファイル で JAVA_HOME
を環境変数に追加することで可能です:
/etc/systemd/system/unit.d/override.conf
[Service] Environment=JAVA_HOME=/usr/lib/jvm/java-11-openjdk
archlinux-java をサポートするために必要なパッケージの前提条件
このセクションでは、代替 JVM 用のパッケージを AUR で提供したいパッケージ製作者が、パッケージを Arch Linux の JVM スキームと統合できる (つまり、archlinux-java
と互換性を持たせる) ようにするための説明を行います。これに関しては、パッケージ制作者は以下のことを行う必要があります:
- 全てのファイルは
/usr/lib/jvm/java-${JAVA_MAJOR_VERSION}-${VENDOR_NAME}
以下に配置すること - java-runtime-common と java-environment-common が提供するシンボリックリンクに対応する全ての実行ファイルが、該当するパッケージにおいて利用可能であること。(訳注: 例えば、java-runtime-common は
/usr/bin/java
シンボリックリンクを提供していますが、あなたの作成したパッケージにもこれに対応する実行ファイルが含まれていなければなりません。その他のシンボリックリンクにおいても同様です。) - シンボリックリンクがまだ [java-runtime-common と java-environment-common に存在しない場合にのみ、
/usr/bin
から実行ファイルへのシンボリックリンクを同梱すること。 - man ページの末尾に
-${VENDOR_NAME}${JAVA_MAJOR_VERSION}
を付けて、衝突しないようにすること (jre8-openjdk のファイルリストを見れば-openjdk8
を付ける man ページがわかります) - 他の JDK、
java-runtime
、java-runtime-headless
、java-environment
を conflicts や replaces として宣言しないこと。 - install 関数で
archlinux-java
スクリプトを使って、他の有効な Java 環境が設定されていない場合に 自身の Java 環境をデフォルトに設定すること (つまり、パッケージは強制的にデフォルトとして設定するべきではありません)。サンプルは公式にサポートされている Java 環境のパッケージのソースを参照。
他の注意事項:
- 任意の Java 環境を必要とするパッケージは、通常通り
java-runtime
、java-runtime-headless
、java-environment
のどれかを依存関係として宣言すること。 - 特定の Java ベンダ を必要とするパッケージは、それに対応するパッケージを依存関係として宣言すること。
- OpenJDK パッケージでは、
provides="java-runtime-openjdk=${pkgver}"
などが宣言されるようになっています。これにより、サードパーティのパッケージではバージョンを指定せずに OpenJDK を依存関係として宣言できるようになっています。
トラブルシューティング
MySQL
JDBC ドライバーは URL のポートを使ってデータベースへの接続を確立するため、同じホストで動作していたとしても"リモート"とされます (すなわち MySQL はデフォルト設定のようにポートを開きません)。そのため、JDBC と MySQL を使うには MySQL のリモートアクセスを有効にする必要があります。MariaDB#リモートアクセスを有効にする の指示に従って下さい。
IntelliJ IDEA
IntelliJ IDEA がシステムの JAVA SDK のパスと共に The selected directory is not a valid home for JDK
と出力する場合、他の JDK パッケージをインストールして、そのパッケージを IDEA の JDK として選択する必要があるかもしれません。
他のウィンドウマネージャになりすます
suckless.org の wmname を使うことで、他のウィンドウマネージャを動かしていると JVM に信じ込ませることができます。これによって、Awesome や Dwm、Ratpoison のようなウィンドウマネージャで発生する Java の GUI レンダリング問題を解決できる場合があります。これがうまく行く理由は、JVM にはリペアレンティング型でない既知のウィンドウマネージャのハードコードされたリストが含まれているからです。皮肉なことに、一部のユーザは、Sun によって Java で記述されたリペアレンティング型でないウィンドウマネージャである LG3D
になりすますことを好みます。"compiz" や "Metacity"、"LG3D" に設定してみてください:
$ wmname ウィンドウマネージャ名
wmname コマンドを実行した後、問題が発生しているアプリケーションを再起動する必要があります。
あるいは、javaagent JavaMatePatch を使うこともできます。これは、MATE においてウィンドウマネージャ名を設定し、Java Swing アプリがフルスクリーン時に不適切な挙動を行うバグを解決するために作成されました。使用するには、-javaagent:JavaMatePatch-1.0.0-SNAPSHOT.jar=ウィンドウマネージャ名
を java オプションに追加してください。
フォントが読みにくい
下の #フォントレンダリングを改善する で書かれている方法でも、フォントによっては読みやすくならないことがあります。このようなときは、使用している MS フォントを変えてみて下さい。ttf-ms-fontsAUR パッケージをインストールしてください。
一部のアプリケーションでテキストが表示されない
一部のアプリケーションでテキストが全く表示されない場合は FS#40871 で提案されているように #ヒントとテクニック のオプションを使うと直るかもしれません。
灰色のウィンドウ、ウィンドウマネージャでアプリがリサイズされない、メニューがすぐに閉じる
標準の Java GUI ツールキットには、「リペアレンティング型でない」ウィンドウマネージャのハードコードされたリストがあります。そのリストに無いウィンドウマネージャを使用すると、一部の Java アプリケーションで問題が発生する可能性があります。最も一般的な問題の1つが、Java アプリケーションが GUI をレンダリングせずにのっぺりとした灰色のボックスとして表示される「灰色のウィンドウ」問題です。クリックでメニューを開いてもすぐに閉じてしまう問題も発生することがあります。
解決に役立つ方法がいくつか存在します:
- #他のウィンドウマネージャになりすます を参照してください。
- jre8-openjdk の場合、
_JAVA_AWT_WM_NONREPARENTING=1
環境変数を設定してください。 - その後のバージョンでは、
AWT_TOOLKIT=MToolkit
環境変数を設定してください。 - xmonad の場合、SetWMName を使用してください。ただし、
XMonad.Hooks.EwmhDesktops
を使うと効果がキャンセルされてしまうことがあります。その場合、>> setWMName "LG3D"
をLogHook
に追加すると解決できる場合があります。
詳細は [1] を参照してください。
JavaFX アプリケーションのデバッグ時にシステムがフリーズする
JavaFX アプリケーションをデバッグする際にシステムがフリーズする場合、JVM のオプション -Dsun.awt.disablegrab=true
を使ってみてください。
https://bugs.java.com/bugdatabase/view_bug?bug_id=6714678 を参照。
JavaFX の MediaPlayer コンストラクタが例外を投げる
JavaFX のサウンドモジュールから MediaPlayer クラスのインスタンスを作成しようとしたときに以下の例外が発生することがあります (Oracle JDK と OpenJDK の両方で発生):
... (i.e. FXMLLoader construction exceptions) ... Caused by: MediaException: UNKNOWN : com.sun.media.jfxmedia.MediaException: Could not create player! : com.sun.media.jfxmedia.MediaException: Could not create player! at javafx.scene.media.MediaException.exceptionToMediaException(MediaException.java:146) at javafx.scene.media.MediaPlayer.init(MediaPlayer.java:511) at javafx.scene.media.MediaPlayer.<init>(MediaPlayer.java:414) at <constructor call> ...
原因は JavaFX が Arch Linux のリポジトリに含まれている新しい ffmpeg と互換性がないためです。
解決方法は ffmpeg-compat-55AUR をインストールすることです。または、先のバージョンがビルドに失敗する場合は、ffmpeg-compat-57AUR をインストールするとうまく行くかもしれません。
参照: https://www.reddit.com/r/archlinux/comments/70o8o6/using_a_javafx_mediaplayer_in_arch/
Java アプリケーションで外部リンクを開けない
Java アプリケーションからウェブブラウザなどのリンクを開けない場合、gvfs をインストールしてください。Desktop.Action.BROWSE メソッドが必要とします。[2] を参照。
QuantumRenderer の初期化でエラー: no suitable pipeline found
考えられる問題と解決策:
- GTK2 が無い。gtk2 をインストールしてください。
- OpenJFX が無い。java-openjfxAUR をインストールしてください。
ヒントとテクニック
Java アプリケーションのほとんどは Java ランタイムの前に変数を設定することで挙動をコントロールすることができます。フォーラムの投稿より、変数を設定するには ~/.bashrc
(もしくは全てのユーザーに適用するには /etc/profile.d/jre.sh
) に次の行を追加してください:
export JDK_JAVA_OPTIONS="-D<option 1> -D<option 2>..."
例えば、システムのアンチエイリアスがされたフォントを使用して swing に GTK のルックアンドフィールを使わせるには:
export JDK_JAVA_OPTIONS='-Dawt.useSystemAAFontSettings=on -Dswing.aatext=true -Dswing.defaultlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel'
このような変数は3つ存在しており、以下の表で後に説明されるオプションが優先されます。
JAVA_TOOL_OPTIONS | javac や jshell といったアプリケーションとツールに影響します。 |
JDK_JAVA_OPTIONS | アプリケーション (java コマンドで実行されるアプリケーション全て) に影響します。Java 9 が必要。 |
(コマンドラインオプション) | "クラス名" の引数の前で指定される引数は Java オプションです。 |
_JAVA_OPTIONS | 古い方法。アプリケーションとツールに影響します。 |
フォントレンダリングを改善する
クローズドソースとオープンソースの Java 実装のどちらもがフォントのアンチエイリアスを不適当に実装していることが知られています。次のオプションを使うことでこれを修正することが可能です: -Dawt.useSystemAAFontSettings=on
, -Dswing.aatext=true
詳しい情報は Java 実行環境のフォントを見てください。
コマンドラインの 'Picked up JDK_JAVA_OPTIONS' メッセージを消す
JDK_JAVA_OPTIONS 環境変数を設定すると java (openjdk) から標準エラー出力に次のようなメッセージが書き出されます: 'Picked up JDK_JAVA_OPTIONS=...'。ターミナルにこのメッセージを表示しないようにするには、シェルのスタートアップファイルから環境変数を消去して、以下のように java のエイリアスを作成してコマンドライン引数を使ってオプションを指定するようにしてください:
SILENT_JAVA_OPTIONS="$JDK_JAVA_OPTIONS" unset JDK_JAVA_OPTIONS alias java='java "$SILENT_JAVA_OPTIONS"'
インタラクティブでないシェル (Java プログラムのランチャースクリプトなど) は、(通常) ~/.bashrc
を読み込みません。ですが、export された変数を親プロセスから継承します (~/.bash_profile
を読み込むログインシェルからどこかの時点でその変数を継承します)。
そうした場合、ファイルが読み取られるのを防ぐために、~/.bashrc
の先頭に文を置いているのが一般的です。そのようにして、変数がデスクトップメニューから起動されたプログラムに渡され、メッセージが邪魔をするインタラクティブシェルの場合は alias が代わりに使用されます (スクリプトでは alias は使用できません)。
GTK のルックアンドフィール
Java プログラムの見た目が酷い場合、swing コンポーネントのデフォルトのルックアンドフィールを設定することができます:
swing.defaultlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel
頑固な Java プログラムはクロスプラットフォームの Metal ルックアンドフィールを使用し続けることがあります。そのような場合には以下のプロパティを設定することで GTK のルックアンドフィールを使うように強制することが可能です:
swing.crossplatformlaf=com.sun.java.swing.plaf.gtk.GTKLookAndFeel
GTK3 のサポート
バージョン 9 より前の Java では、GTK のルックアンドフィールが GTK2 に対してリンクされていますが、新しいデスクトップアプリケーションは GTK3 を使用します。GTK バージョン間の非互換性のせいで、GTK3 アプリに GUI の Java プラグインが存在すると、Java の GUI を開いたときにアプリがクラッシュする場合があります。同じプロセスで GTK2 と GTK3 を混ぜることはできません。例えば LibreOffice 5.0 などがこれに該当します。
GTK ルックアンドフィールは GTK バージョン 2
、2.2
、そして 3
に対して実行でき、デフォルトは GTK3 です。これは、次のプロパティを設定することで上書きできます:
jdk.gtk.version=2.2
HiDPI
GUI フレームワークによっては、他の方法を使うことで HiDPI#Java アプリケーション を利用可能にできます。
2D のパフォーマンスの向上
OpenGL ベースのハードウェアアクセラレーションパイプラインに切り替えることで 2D の性能が改善します:
export JDK_JAVA_OPTIONS='-Dsun.java2d.opengl=true'