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の使用に関する簡単な説明

推薦する

CSS フロート(float, clear)の人気の解説と体験談

私はかなり昔に CSS に触れましたが、フローティングについてはいつも混乱していました。私の理解が浅...

ショートビデオ(Douyin)の透かし除去ツールの実装コード

目次1. まず最初のリンクを取得する2. ブラウザでこのリンクを開いてください3. アドレスを開くと...

iFrameは背景を覆うポップアップレイヤーとして使うのに最適です

最近、私は「ぶどうコレクション」というプロジェクトに取り組んでいます。簡単に言うと、Budou ペー...

Linux で実行中のバックグラウンド プログラムを表示および終了する方法

Linux タスク管理 - バックグラウンド実行と終了fg、bg、ジョブ、&、ctrl + ...

同じ日の最初の3つのデータを取得するためのMySQLタイムラインデータ

テーブルデータを作成する テーブル `praise_info` を作成します ( `id` bigi...

Mysql の主キー インデックスと非主キー インデックスの違いについて簡単に説明します。

目次インデックスとは何か主キーインデックスと通常のインデックスの違いインデックスにはどのデータ構造が...

支払いカウントダウンを実現し、ホームページに戻るためのjs

ホーム ページに戻るための支払いカウントダウン ケースの概要: シンプルな js 構文、getEle...

MySQLデータベースのリアルタイムバックアップの知識ポイントを詳しく解説

序文リアルタイムのデータベース バックアップの必要性は非常に一般的です。MySQL 自体はレプリケー...

MySQLは、where in()順序ソートを実装するためにfind_in_set()関数を使用します。

この記事では、MySQL で find_in_set() 関数を使用して where in() の順...

CSS スタイルのリセットとクリア (異なるブラウザで同じ効果を表示するため)

異なるブラウザ間でページの表示を一致させるためには、フロントエンド開発において CSS スタイルのク...

純粋な CSS で DIV サスペンションを実装するサンプル コード (固定位置)

DIV フローティング効果 (固定位置) は CSS のみで実装されており、IE8、360、Fir...

Linux インストール Redis 実装プロセスとエラー解決

今日、redis をインストールしたところ、今までになかったいくつかのエラーが発生しました。ここで記...

Springboot プロジェクトに動的にパラメータを渡すための Docker の実装方法

背景最近、Docker 初心者の友人から、毎回プロジェクト構成ファイルにハードコーディングしてサービ...

MYSQLの文字セット設定方法(端末の文字セット)の詳しい説明

序文ターミナルを使用してデータベースまたはテーブルを作成するたびに、文字セットが latin1 であ...

MySQLで適切なインデックスを選択する方法

まずは栗を見てみましょう EXPLAIN select * from employees where...