jhat - Java ヒープ解析ツール

形式

jhat [ options ] <heap-dump-file>

パラメータ

options
オプションを使用する場合、コマンド名の直後に記述してください。

heap-dump-file
ブラウズ対象となる Java バイナリヒープダンプファイル。複数のヒープダンプを含むダンプファイルの場合、「foo.hprof#3」のようにファイル名の後に「#<number>」を付加することで、ファイル内の特定のダンプを指定できます。

説明

jhat コマンドは、java ヒープダンプファイルを解析し、Web サーバーを起動します。 jhat を使えば、お好みの Web ブラウザを使ってヒープダンプをブラウズできます。 jhat は、「ある既知のクラス「Foo」のすべてのインスタンスを表示する」といった、事前に設計されたクエリのほか、OQL (Object Query Language) もサポートします。OQL のヘルプには、jhat によって表示される OQL ヘルプページからアクセスできます。デフォルトポートを使用する場合、OQL のヘルプは http://localhost:7000/oqlhelp/ で利用可能です。

Java のヒープダンプを生成するには、いくつかの方法があります。

  • jmap の -dump オプションを使って実行時にヒープダンプを取得する。
  • jconsole のオプションを使って HotSpotDiagnosticMXBean 経由で実行時にヒープダンプを取得する。
  • -XX:+HeapDumpOnOutOfMemoryError VM オプションを指定すると、OutOfMemoryError のスロー時にヒープダンプが生成される。
  • hprof を使用する。

注: このツールは試験的なものであり、将来の JDK のバージョンでは利用できなくなる可能性があります。

オプション

-stack false/true
オブジェクト割り当て呼び出しスタックの追跡を無効にします。ヒープダンプ内で割り当てサイト情報が使用できない場合、このフラグを false に設定する必要があります。デフォルトは true です。
-refs false/true
オブジェクトへの参照の追跡を無効にします。デフォルトは true です。デフォルトでは、ヒープ内のすべてのオブジェクトについて、バックポインタ (指定されたオブジェクトをポイントしているオブジェクト。参照者または受信参照とも呼ばれる) が計算されます。
-port port-number
jhat の HTTP サーバーのポートを設定します。デフォルトは 7000 です。
-exclude exclude-file
「到達可能なオブジェクト」のクエリから除外すべきデータメンバーの一覧を含むファイルを指定します。たとえば、このファイルに java.lang.String.value が含まれていた場合、特定のオブジェクト「o」から到達可能なオブジェクトのリストを計算する際に、java.lang.String.value フィールドに関連する参照パスが考慮されなくなります。
-baseline baseline-dump-file
ベースラインとなるヒープダンプを指定します。両方のヒープダンプ内で同じオブジェクト ID を持つオブジェクトは「新規ではない」としてマークされます。その他のオブジェクトは「新規」としてマークされます。これは、異なる 2 つのヒープダンプを比較する際に役立ちます。
-debug int
このツールのデバッグレベルを設定します。0 は「デバッグ出力なし」を意味します。より大きな値を設定すると、より冗長なモードになります。
-version 
バージョン番号を報告したあと、終了します。
-h 
ヘルプメッセージを出力して終了します。
-help 
ヘルプメッセージを出力して終了します。
-J<flag> 
jhat が実行されている Java 仮想マシンに <flag> を渡します。たとえば、512M バイトの最大ヒープサイズを使用するには、-J-Xmx512m とします。

関連項目


Copyright © 2006 Sun Microsystems, Inc. All Rights Reserved.

Sun
Java Software