序文 Linux 運用保守エンジニアとして、日々の業務の中で Linux サーバーの CPU 負荷が 100% に達し、高い状態が続く状況に遭遇することがあります。CPU 負荷が高い状態が続くと、業務システムの正常な動作に影響を及ぼし、企業に損失をもたらします。 このような状況に遭遇すると、多くの運用および保守担当者が困惑することがよくあります。CPU 過負荷の問題の場合、通常は次の 2 つの方法を使用して、問題を迅速に特定できます。 方法1 ステップ1: 使用
CPUを過剰に使用しているプロセスのPIDを見つける ステップ2: 使用
プロセス内で最も多くのリソースを消費するスレッドのIDを見つける ステップ3: 使用
スレッド ID を 16 進数に変換します (文字は小文字にする必要があります)
ステップ4: 実行
スレッドのステータス情報を表示する 方法2 ステップ1: 使用
CPUを過剰に使用しているプロセスを見つける ステップ2: 使用
スレッド情報を取得し、CPUを大量に消費するスレッドを見つける ステップ3: 使用
必要なスレッドIDを16進形式に変換します ステップ4: 使用
スレッドスタック情報を印刷する ケーススタディ シナリオの説明 実稼働環境での JAVA プロセスの CPU 使用率が高い場合のトラブルシューティング 解決プロセス 1. topコマンドによると、PID 2633のJavaプロセスがCPUの最大300%を占有し、障害が発生していることがわかります。 2. プロセスを見つけた後、特定のスレッドまたはコードを見つけるにはどうすればよいでしょうか? まず、スレッド リストを表示し、CPU 使用率の高いスレッドで並べ替えます。 [root@localhost ~]# ps -mp 2633 -o スレッド、tid、時間 | sort -rn 結果は次のとおりです。 CPU 消費量が最も高いスレッド (TID) 3626 が見つかりました。このスレッドは 12 分間 CPU 時間を占有していました。 3. 必要なスレッドTIDを16進形式に変換する [root@localhost ~]# printf "%x\n" 3626 18 18 18 4. 最後に、jstack コマンドを使用して、プロセスの下にあるこのスレッドのスタック情報を出力します。 [root@localhost ~]# jstack 2633 |grep "e18" -A 30 トラブルシューティングと比較して、障害を発見することも同様に重要です。 Zabbix、Nagios、Alibaba Cloud Monitoring(クラウド サーバー用)など、市場に出回っているほとんどの監視ソフトウェアは、サーバー負荷のリアルタイム監視を実現できます。しかし、ほとんどのソフトウェアでは、運用・保守担当者がルールを積極的に設定したり、テストを実施して問題を発見する必要があります。受動的にアラートを受信するにはどうすればよいでしょうか。 王教授、実用的な運用・保守ソフトウェアをお勧めしたいと思います。Alibaba Cloud にビジネスを展開しているユーザーは、監視が必要な読み取り専用の AcessKey をバインドするだけで、クラウド リソースのアラーム情報を対応するチーム メンバーに迅速に通知できます。 アクティブ アプローチからパッシブ アプローチへの変更により、一方では運用および保守エンジニアの作業負荷が軽減され、他方では O&M エンジニアがアラームを見逃したり無視したりする可能性も軽減されます。 要約する 以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。 以下もご興味があるかもしれません:
|
>>: MySql 8.0.11 のインストール プロセスと Navicat とのリンク時に発生する問題の概要
この記事の例では、ショッピングカートの加算と減算、価格計算を実装するためのjsの具体的なコードを共有...
1. Python 3をインストールする1. 依存パッケージをインストールしますyum instal...
Vue+Openlayerはmodifyを使って要素を変更します。具体的な内容は以下のとおりです。 ...
解決策は次のとおりです。 1. コンテナを強制削除する docker rm -f ジェンキンス2. ...
目次依存関係をインストールするブーストをインストールMySQLをコンパイルしてインストールする構成依...
目次Dockerコンテナのデータ量データボリュームの使用方法1: コマンド-vを使用して直接マウント...
目次序文文章1. JavaScriptコードの実行プロセスに関連する概念2. 実行コンテキストと実行...
Vue プロジェクトで div ホイールのズームインとズームアウト、ドラッグ効果、キャンバス効果に似...
目次1. 関数パラメータのデフォルト値1.1 関数パラメータのデフォルト値の指定1.2 分離割り当て...
行内では、明るい境界線の色を個別に定義できます。基本的な構文<TR ボーダーカラーライト=co...
1. forEach() は map() に似ています。これも渡された関数に各要素を順番に適用します...
オペレーティング システム win10 MySQL は、公式 Web サイトからダウンロードした 6...
目次序文1. 従来のVueコンポーネント1. メインコンポーネントコード: 2. 使用方法3. 成果...
<a> タグは主に、ハイパーリンクまたはアンカー リンクとも呼ばれるリンクとブックマーク...
関数を記述できます。主に正規表現を使用して判断を行います。入力文字が空の場合は、「-」を使用して置き...