Linux のプロセスクラッシュの原因をコアダンプ技術を使用して追跡する簡単な分析

Linux のプロセスクラッシュの原因をコアダンプ技術を使用して追跡する簡単な分析

最近、プロジェクトで問題が発生しました。サーバー側のプログラムが突然クラッシュして終了しました。クラッシュの原因、つまりプロセスが終了したときに実行されていた関数とそのステータスを特定するために、コアダンプ技術を使用しました。

システムで coredump が有効になっている場合、より正確には、現在のシェル環境で coredump が有効になっている場合、現在のシェル環境のプログラムがクラッシュして終了すると、その時点でのプロセス スタックのメモリ状態がコア ファイルに書き込まれます。 gdb を使用して、このコア ファイル (gdb a.out core) に保存されているスタックのステータスを表示します。 (コアダンプとシェルの詳細については、私の別のブログ「dotnet-dump を使用して .net core 3.0 が CPU を 100% 占有する理由を調べる」を参照してください。gdb については、「gdb デバッグ コマンドの使用と概要」を参照してください)

コア ファイルのデフォルトの場所は実行可能ファイルの場所であり、デフォルトの名前は core です。場所と名前は設定できます。私の設定は次のとおりです。

mkdir /home/corefile 
echo "/home/corefile/core-%e-%p-%t" > /proc/sys/kernel/core_pattern

この方法では、生成されたコア ファイルは /home/corefile ディレクトリに配置され、コア ファイル名は core-%e-%p-%t の形式で表示されます。ここで、%e は実行可能ファイルの名前、%p はプロセス、%t はコア ファイルが生成された時刻 (Unix 時間であることに注意してください) を表します。

コアダンプを引き起こす可能性があるルーチンは次のとおりです。

交差した線は、コアダンプが発生する場所です。実行後、/home/corefile ディレクトリに次のファイルが生成されます。

[root@localhostwin7]# ls /home/corefile/ 

a.out は実行ファイル名、5082 は PID、1490760381 はファイルが生成された Unix 時間です。 a.out ファイルと core ファイルをディレクトリに配置し、次のコマンドを使用します。

gdb a.out core-a.out-5082-1490760381

gdb に入り、backtrace コマンドを使用して、プロセスが終了したときのスタックのメモリ ステータスを次のように表示します。

プロセスが終了すると、最後に実行される関数は square 関数であることがわかります。 ————————————————

要約する

上記は、Linux でプロセス クラッシュの原因をトレースするために coredump テクノロジを使用する方法について紹介したものです。お役に立てば幸いです。ご質問がある場合は、メッセージを残してください。すぐに返信いたします。

<<:  vscodeを使用してReact Native開発環境を構築する方法を教えます

>>:  SQL文におけるGROUP BYとHAVINGの使用に関する簡単な説明

推薦する

Linux で Nginx ロード バランシングを使用して複数の Tomcat を構成する方法

Linux に nginx と複数の tomcat をインストールする方法はここでは紹介しません。不...

Tik Tok サブスクリプション ボタンのアニメーション効果を実現する CSS

少し前にTik Tokを見ていて、フォローするときのボタンアニメーションがとても美しいと思ったのと、...

JS に依存せずにレスポンシブ レイアウトを実現する CSS3 モバイル vw+rem メソッド

1. はじめに(1)vw/vhの紹介使用する前に、vw と rem とは何か、その機能について簡単に...

springcloud alibaba nacos linux 設定の詳細なチュートリアル

まず、github から nacos の圧縮パッケージをダウンロードします: https://git...

フロントエンド開発に必要な共通ツール機能のまとめ

1. 時刻の書式設定とその他の方法moment.jsライブラリファイルの使用をお勧めします2. テン...

Vue で配列をクリアするいくつかの方法 (要約)

目次1. はじめに2. データを消去するいくつかの方法2.1 ref() の使用2.2 スライスの使...

Springboot+Vue-Cropperでアバターの切り取りとアップロードの効果を実現

アバターをアップロードするにはVue-Cropperコンポーネントを使用します。参考までに具体的な内...

Docker+Jenkinsによる自動デプロイの実現方法

Code Cloud を使用して Git コード ストレージ ウェアハウスを構築するhttps://...

Ubuntu 18でターミナルを美しいコマンドラインプロンプトに変更する方法

VMware と Ubuntu を再インストールしましたが、コマンドラインプロンプトが単調すぎて美し...

仮想マシン VMware に Kali Linux をインストールする最新の超詳細なグラフィック チュートリアル

目次1. システムイメージファイルをダウンロードする2. 新しい仮想マシンを作成する3. Kali ...

MySQL データベース JDBC プログラミング (Java は MySQL に接続します)

目次1. データベースプログラミングの基本条件2. Java でのデータベースプログラミング: JD...

Reactは動的ポップアップウィンドウコンポーネントを実装します

UI コンポーネントを作成するときに、アニメーションを考慮しなければ、アニメーションを実現するのは非...

Reactはページング効果を実装する

この記事では、Reactでページング効果を実現するための具体的なコードを参考までに紹介します。具体的...

IPとポートが接続可能かどうかを検出する方法

Windows コマンドテルネット形式: telnet IP ポート場合: テルネット 191.1....

VMware vSphere 6.7 (ESXI 6.7) のグラフィック インストール手順

環境: VMware VCSA 6.7 (VMware-VCSA-all-6.7.0-8169922...