JVM: 内部情報をお伝えします

JVM: 内部情報をお伝えします

[[361071]]

ほとんどのユーザーは、Java リフレクションの使用に精通しています。特にオープンソースフレームワークでは広く使用されています。リフレクションを通じて、Java クラスの情報を取得できます。ヒープやスレッドの使用状況、作成されたオブジェクトのメモリ アドレスやロードされたクラスの内容など、JVM の内部情報についてはどうでしょうか。

実際、JVM には、上記のような、人生における内部メッセージに似た内部情報が多数存在します。一部の大規模なアプリケーションでは、API 認証を通じてのみ一部のユーザー データを取得できることが想像できます。一般ユーザーが通常の使用方法でこれらのコンテンツを入手することは不可能です。 JVM 上で実行される通常の Java アプリケーションと同様に、JVM に関する情報を取得することは困難です。結局のところ、JVM はより低いレベルにあり、C++ で開発されています。

JVM はこの内部情報を教えてくれるのでしょうか?

JVM は、内部情報を公開するためのいくつかの外部インターフェースを提供します。 SA はこれらのインターフェースを通じてのみ、JVM 内部クラスの構造とアドレスにアクセスし、最下層から JVM 内部操作の詳細を観察できます。

SA グラフィカル インターフェイスで HSDB の内部を見ると、長いメニュー リストが表示されます。そのほとんどには、通常の Java アプリケーションでは取得できない「内部情報」が含まれています。

これらはすべてどのように実装されるのでしょうか?これについて言えば、gHotSpotVMStructs について言及する必要があります。

JVM によって提供されるインターフェースの中核は、gHotSpotVMStructs 構造です。元のヒープ アドレス、スレッド アドレス、スタック アドレスなど、JVM 内の多くの情報を公開します。

gHotSpotVMStructs 構造体は、多くのクラスとこれらのクラスのフィールド情報を指します。各クラスには一連のフィールドがあり、各フィールドには独自の名前、タイプ、静的かどうかなどが設定されます。静的フィールドの場合は、この構造を使用してその値にアクセスすることもできます。静的オブジェクト フィールドの場合、この構造体はターゲット オブジェクトのアドレスも提供します。このルート アドレスを通じて、コンパイラ、スレッド、ヒープなど、JVM 内のいくつかのコンポーネントのリバース チェックを開始できます。

したがって、JVM の内部情報を取得して理解するための鍵は、gHotSpotVMStructs 構造内のデータを解析することです。 JVM は、内部型システムのアドレスとルート オブジェクトのアドレスを公開するだけでなく、このデータを解釈するために使用される追加のシンボルと値も公開します。これには、クラスの説明情報と、このクラス内の各フィールドのオフセットが含まれます。さらに、JVM 開発者は、JVM 内の C++ クラスのフィールドを手動でマップしてグローバル gHotSpotVMStructs 構造にロードする一連の作業を実行しました。

SA はこの情報を解析する最良の例です。グラフィカル インターフェースを通じて、この情報を解析して何を学んだかを直感的に感じることができます。 gHotSpotVMStructs によって公開される情報を変換することで、Java ラッパー クラスを生成できます。これらのラッパー クラスによって提供されるインターフェイスにより、通常の Java アプリケーションで使用される API と同様に、JVM の内部システムに簡単かつ便利にアクセスでき、内部データへのアクセスと解析の問題が解決されます。

この情報に基づいて、他のデバッグ ツールや診断ツールも実装されます。

SA を使用する方法は、実際には「ptrace」システム コールを介して行われ、これにより、ターゲット JVM プロセスが一時停止され、gHotSpotVMStructs のメモリ情報の読み取りが開始されます。

上記の内容を読めば、SA がどのように機能するかが大体理解できます。このような要件がある場合、SA などのツールを使用して他のユーザーが JVM 情報を取得することを禁止しますか?

ほら、私が打ったところを指しているよ。答えは、gHotSpotVMStructs をリセットすることです。このツールではこの情報を解析できません。

Stackoverflow には、エージェントをコンパイルし、JVM の起動時にアタッチして、gHotSpotVMStructs を 0 に設定するという解決策があります。

  1. 外部 void *gHotSpotVMStructs;
  2.  
  3. int Agent_OnLoad(void *vm, char *options, void *reserved) {
  4. gHotSpotVMStructs = 0;
  5. 0を返します
  6. }

起動すると、JVM に接続されます。

  1. java -agentpath:/path/を /libnostructs.so...

SA ツールを再度実行すると、問題があることを示す例外がスローされます。

  1. スレッド「main」例外が発生しましたjava.lang.reflect.InvocationTargetException
  2. sun.reflect.NativeMethodAccessorImpl.invoke0 (ネイティブ メソッド)
  3. sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
  4. sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
  5. java.lang.reflect.Method.invoke(Method.java:498)
  6. sun.tools.jstack.JStack.runJStackTool(JStack.java:140)
  7. sun.tools.jstack.JStack.main(JStack.java:106)
  8. 原因: java.lang.RuntimeException: gHotSpotVMStructs がリモート プロセス適切に初期化されませんでした。できない 続く 
  9. sun.jvm.hotspot.HotSpotTypeDataBase.readVMStructs(HotSpotTypeDataBase.java:418)
  10. sun.jvm.hotspot.HotSpotTypeDataBase.<init>(HotSpotTypeDataBase.java:91)
  11. sun.jvm.hotspot.HotSpotAgent.setupVM(HotSpotAgent.java:395)
  12. sun.jvm.hotspot.HotSpotAgent.go(HotSpotAgent.java:305)
  13. sun.jvm.hotspot.HotSpotAgent.attach(HotSpotAgent.java:140)
  14. sun.jvm.hotspot.tools.Tool.start(Tool.java:185)
  15. sun.jvm.hotspot.tools.Tool実行(Tool.java:118)
  16. sun.jvm.hotspot.tools.JStack.main(JStack.java:92)
  17. ... 6件以上

この記事はWeChatの公開アカウント「Tomcat Things」から転載したもので、以下のQRコードからフォローできます。この記事を転載する場合は、Tomcat Things の公開アカウントにご連絡ください。

<<:  ローカルマシンからKubernetesの学習を始める

>>:  テクノロジーには暖かさがある:天一雲がラサの暖房に「スマートブレイン」を導入

推薦する

SEOの共有方法: ウェブサイトの修正に関するヒント

昨日、その友人は、私のウェブサイトにいくつかのコラムを追加して、私のWebサイトを見せてくれたことを...

gcore - ロシアの VPS/無制限のトラフィック/3.25 ユーロ/512M RAM/20g SSD

gcorelabs のモスクワ 2 データ センターは新しく開設され、KVM 仮想化、純粋な SSD...

データ所有権の観点からクラウド移行の過程を見る

ビジネスをクラウド コンピューティングに移行することは、世界中の企業に多大なチャンスをもたらします。...

2020 年のクラウド コンピューティングの 5 つのトレンド

企業はエッジ コンピューティング、自動化、業界固有のクラウド プラットフォームの導入に備えていますか...

自分の悪い性質を排除しなければ、SEO はスープを変えるだけで中身を変えないケースになってしまいます。

過去6か月間、中国の検索エンジンには大きな変化があったと言えます。まず、百度はウェブサイトの大幅なア...

企業でハイブリッド クラウドを導入する 3 つの方法のうち、どれが適切でしょうか?

ハイブリッド クラウドへの道は、多くの場合、一連の偶然と事故によって舗装されています。 Red Ha...

今すぐ購入: 1qcloud-$4.97/xen/onapp/1g メモリ/30g SSD/無制限トラフィック

クリスマスが近づいてきました。オンラインになってまだ 1 年も経っていない VPS 販売業者 1qc...

ビッグニュース: Azure SQL Database マネージドインスタンスが中国でリリースされます

[51CTO.com からのオリジナル記事] 最近、Microsoft は今年最も重要なクラウド サ...

ブランドマーケティング:デュレックスとKFCのマーケティングの失敗を分析!

マーケティングが得意なら、商品を売って楽しい時間を過ごせるでしょう。有名人の支持や国境を越えた協力に...

すべてのプロジェクトに影響を与える3つの主要なVDIの課題

ベンダーが示唆するほど簡単に構築および保守できるテクノロジーベースのプロジェクトは多くなく、VDI ...

WeChatでのビジネス:購入とカスタマイズWeChatはショッピング天国になった

1 か月目: 収益 700 元、2 か月目: 収益 2,000 元、3 か月目: 収益 3,000 ...

瑞樹情報:攻撃と防御の新たなトレンドを察知し、ダイナミックなセキュリティ製品で企業を守る

インターネット時代において、セキュリティ状況がますます複雑化するにつれて、セキュリティ攻撃・防御訓練...

大学生が初めて職場に入りSEOに従事する際の評価期間をどうやってうまく通過できるか

著者は、ウェブサイトの最適化を行っている友人の多くが大学を卒業していることに気付きました。彼らが初め...

IBM Cloud Private: マイクロサービス アーキテクチャーに基づいて IT の俊敏性を高める

[51CTO.com からのオリジナル記事] 「マイクロサービス」という概念には長い歴史があります。...