最近、プロジェクトで問題が発生しました。サーバー側のプログラムが突然クラッシュして終了しました。クラッシュの原因、つまりプロセスが終了したときに実行されていた関数とそのステータスを特定するために、コアダンプ技術を使用しました。 システムで 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 に入り、backtrace コマンドを使用して、プロセスが終了したときのスタックのメモリ ステータスを次のように表示します。 プロセスが終了すると、最後に実行される関数は square 関数であることがわかります。 ———————————————— 要約する 上記は、Linux でプロセス クラッシュの原因をトレースするために coredump テクノロジを使用する方法について紹介したものです。お役に立てば幸いです。ご質問がある場合は、メッセージを残してください。すぐに返信いたします。 |
<<: vscodeを使用してReact Native開発環境を構築する方法を教えます
>>: SQL文におけるGROUP BYとHAVINGの使用に関する簡単な説明
Laravel 5.4 のデフォルトの utf8mb64 文字エンコーディングをサポートするには、M...
この記事では、Xshell と関連する構成の一般的な問題について説明します。この記事の構成は、主に ...
1つ。 Nexus プライベート サーバーを構築する理由は何ですか?社内の開発メンバーは全員外部ネッ...
この記事では、例を使用して、MySQL クエリのソート関数とクエリ集計関数の使用方法を説明します。ご...
序文MySQLでは、準備、実行、割り当て解除を正式にはPREPARE STATEMENTと呼びます。...
最近、同社はitpubを皮切りに、コーポレートウェブサイト傘下の全サイトの評価を開始した。そのために...
1. nacosデータベースを再開します。データベース名nacos_configユーザー名とパスワー...
docker を使用すると、ファイルをマウントできない場合があります。これは、仮想マシンの共有フォル...
この記事では、主に Vue バックグラウンド管理システムのページング機能の実装を紹介し、次のように共...
1. ユーザーとグループを追加する1. mysqlユーザーグループを追加する # グループ追加mys...
HTML テーブルを使用する場合、行間隔を変更する必要がある場合がありますが、余白、パディング、折り...
スタイルシートCSS (カスケーディング スタイル シート) は、HTML Web ページを美しくす...
結合クエリ結合クエリとは、2 つ以上のテーブル間のマッチング クエリを指し、一般的には水平操作と呼ば...
docker によってプルされたコマンドは、デフォルトでは /var/lib/docker/ フォル...
開発プロセス中に、MySQL データベースを復元した後にデータベース データに文字化けが発生した場合...