序文 1. 基本的な概要 プログラムの起動は非常に簡単で、通常は起動時にいくつかのリソースの事前ロードが実行されます。ただし、シャットダウン時に、プリロードされたリソースが起動時に完全にクリーンアップされないことがあるため、フック関数を使用してこれを完了することができます。 2. JVMシャットダウンシナリオの分類 写真を見てみましょう。この写真は CSDN ブログの BarryWang から提供されたもので、ここで説明したいと思います。 上記からわかるように、JVM のシャットダウンは主に 3 つのカテゴリに分かれており、1 つ目は通常のシャットダウン、2 つ目は異常なシャットダウン、3 つ目は強制シャットダウンです。最初の 2 つの方法では、フック関数を使用して正常に閉じることができますが、強制的に閉じる場合はフック関数は機能しません。 これらの概念を念頭に置いて、デモンストレーション用のケースを直接使用し、分析してみましょう。 1. コードデモンストレーションフック関数 1. JVMが正常にシャットダウンする コードを直接見てみましょう。
コンソール出力を見ると、メインアプリケーションの実行後にフック関数が呼び出され、その後 JVM が正式にシャットダウンされることがわかります。 2. 異常閉鎖 コードのデモを直接見てみましょう。ここでは、異常終了の 2 番目の OOM 状況を示します。まずヒープ サイズを 20M に設定し、コード内に 500M のオブジェクトを作成すると、OOM が発生します。パラメータは -Xmx20M です。
コンソールから、異常終了した場合でもフック関数が呼び出されることがわかります。 3. 強制終了 ここでは、Runtime.getRuntime().halt() を使用して、強力なシャットダウンを示します。このメソッドと System.exit の違いは、System.exit はフック関数を実行しますが、Runtime.getRuntime().halt() は実行しないことです。
上記のコードの出力から、Runtime.getRuntime().halt(1) を呼び出すと JVM が強制的にシャットダウンされ、フック関数は実行される前にシャットダウンされることがわかります。ただし、System.exit を使用すると、引き続き実行されます。したがって、JVM をシャットダウンするには通常、System.exit が使用されます。 4.フック機能を削除する 上記はフック関数の役割を示しています。簡単に取り外せる場合もあります。
さて、フック関数の基本的な動作はここに書かれています。使い方は比較的簡単です。しかし、以前に Spring の起動プロセスを見たことがあるのですが、その起動プロセスをもう一度見てみると、フック関数も使用されていることがわかりました。 2. 典型的なアプリケーションシナリオ 1. Springを使用する Spring がコンテキストを閉じるときに、フック関数を使用して残りのリソースを閉じることができます。この方法は、ApplicationContext を使用してフック関数を登録することです。
ソース コードからわかるように、Spring は実際にシャットダウンするために Java のフック関数を呼び出します。 2. その他の用途 多くのブログで、Spark と Hadoop のシャットダウンも目にしました。ソースコードを読んでいないので、ここでは結論を述べます。その他の使用シナリオでは、基本的に Java フック関数が呼び出されて実行されます。 結論は JVM をシャットダウンするときに、フック関数をカプセル化してスレッドを正常にシャットダウンすることができます。ただし、使用時には以下の点に注意する必要があります。 1. フック関数は本質的にはスレッドである 複数のフックが同時に実行され、JVM はそれらの実行順序を保証しません。したがって、一連の操作を 1 つのフックで実行するのが最適です。 2. フック内に新しいフックを作成できなくなりました シャットダウン フックでは、フックの登録や削除などの操作を実行することはできません。そうしないと、JVM によって IllegalStateException がスローされます。 System.exit() も使用できません。前述のように、System.exit() はフック関数の実行をトリガーしますが、Runtime.halt() はシャットダウンを強制できるため、Runtime.halt() でも実行できます。 3. フックには時間のかかる操作を入れないのがベスト フック関数は主に残りのリソースを閉じるために使用されるため、時間のかかる操作は実行しないでください。 はい、とりあえずここでやめておきます。関連する経験的方法、そして経験と思考に関するいくつかの本をお勧めします。クラスメートたちに刺激を与えてくれることを願っています。 この記事はWeChat公式アカウント「Yugong Yaoyishan」から転載したものです。下のQRコードからフォローできます。この記事を転載する場合は、Yugongyaoyishanの公式アカウントまでご連絡ください。 |
<<: クラウドコンピューティングがデジタル変革の原動力となる
2018年最もホットなプロジェクト:テレマーケティングロボットがあなたの参加を待っていますSEO は...
IT Homeは11月29日、米国ラスベガスで本日開催されたAmazonの「AWS re:Inven...
SEO 業界は、ウェブサイトのプロモーションにおいて最も人気のある技術業界の 1 つになりました。現...
PacificrackのVPSはどうですか? ここでは、スクリプトを使用して、オフピーク時間と夕方の...
最近、Huawei Cloud は業界アナリストとクラウド アプリケーションの専門家を招き、コンテナ...
WeChatの紹介WeChat(公式サイト:http://weixin.qq.com/)は、テンセン...
クラウド MSP のトレンドが台頭する中、エンタープライズ市場の大手メーカーである Lenovo も...
最近、Cloud Native Computing Foundation (CNCF) が第 3 回...
Kafka のメッセージはディスクに保存またはキャッシュされます。一般的に、ディスク上のデータの読み...
Baidu はどうすればできるだけ早く新しいサイトを追加できるでしょうか? これはすべてのウェブマス...
私は香港のデータセンターでHengchuang TechnologyからVPSを取得しました。この記...
マルチクラウドは実際には IT 用語です。もちろん、現在ではパブリック クラウド、プライベート クラ...
設計では次のような問題がよく発生します。 1. ウェブサイトを携帯電話、タブレット、PC と互換性を...
企業サイトは、細部から始めてサイトのユーザーエクスペリエンスを向上させるにはどうすればよいのでしょう...
一昨日、WeChatはWeChat Storesのニュースを正式に発表しました。しばらくの間、WeC...