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の学習を始める

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

推薦する

コミュニティサービスO2Oゴールドラッシュ? それはそんなに単純ではありません!

コミュニティサービスO2Oは、インターネットの「仮想から実用への転換」におけるもう一つの大きな前進で...

ロシアのホスティングプロバイダー invs.ru、ロシアの VPS+サーバー+仮想ホストの簡単な紹介

INOVENTICAグループ傘下のinvs.ruは、1999年から運営されているロシアの老舗ブランド...

JD Financeのアプリケーション中心のDevOpsシステム構築

DevOps は、アジャイル、スクラム、XP から進化し、運用と保守の分野にまで広がった新しい動きで...

統合マーケティングの利点は徐々に顕著になってきており、私たちはそれにもっと注意を払う必要がある。

Baiduのアルゴリズムが何度も変更されるにつれて、これまで高く評価されていたSEO手法が軽視される...

クイックパケット - $35/L5520/16g メモリ/1T ハードディスク/20T トラフィック/G ポート/5IP/IPMI

quickpacket、最新ニュース: アトランタ データ センターのサーバーが特別価格で入手可能で...

個人ウェブサイトにとって、広告は本当に唯一の収益モデルなのでしょうか?

はじめに: これは著者の 2 回目の投稿です。この記事は質の高いもので、私の考えを広げてくれました。...

Tik Tokプロモーションスキル:3つのステップと7つのポイント

ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービスいつからか、道路脇に貼っ...

権威ある百度製品を活用してキーワードランキングを向上させる方法

良いウェブサイトランキングは、高品質の外部リンクの構築と切り離せないことは誰もが知っていると思います...

CNCF 2020 クラウド ネイティブ アプリケーション調査レポート: コンテナの採用率は 2016 年以降 300% 増加

現在、CNCF コミュニティは発展を続けており、ユーザーによるオープンソース テクノロジの応用がます...

競合他社を分析し理解することがSEOの第一歩です

さまざまなユーザーと向き合うとき、彼らのニーズを理解し、彼らの好みに応える方法に加えて、私たちが最も...

クラウドネイティブのアプリケーションとデータは安全である必要がある

クラウドネイティブ アプリケーションの一部としてデータを管理するのは困難です。多くの企業にとって、新...

GoogleとBaiduの検索結果をフィルタリングする方法

中国で検索エンジンを使うのは目新しいことではありません。普通のネットユーザーの約90%は、オンライン...

実践サロンの必需品 | Qiu Ma が APP 運用パスから上位 10 チャネルの長所と短所を分析します

店内のサロンを見逃してしまったことを残念に思うお客様が多すぎました!ウェイターは、秋馬サロンでのスピ...