it-swarm-ja.com

存在せずにCPU使用率の急上昇を調査するにはどうすればよいですか?

深夜にCPUを大量に消費しているサーバーがありますが、負荷が高いはずがありません。これにより、一部のデータベース呼び出しがタイムアウトします。CPU使用率が50%を超えた場合にトリガーするように、PerfMonでいくつかのアラートを設定しました。これは、データベースのタイムアウトと同時に発生するCPUスパイクと一致しているようです。

ある種のスケジュールされたタスクだと思いますが、WindowsとSQL Serverのスケジュールされたタスクのリストを調べましたが、何も見つかりませんでした。 Windowsイベントログには、データベースのタイムアウトと、CPU使用率が急上昇したことを示すPerfMonエントリのみが含まれます。

私の質問はこれです:物理的に存在せずにCPUスパイクを引き起こしているプロセスを特定するにはどうすればよいですか?午前2時にサーバーにログインする必要は本当にありません。

更新:問題は私が取り組んでいる製品にあったことが判明しました。問題は通常の勤務時間中に現れ始め、結局私はいくつかの卑劣なパフォーマンス調査技術に頼る必要はありませんでした。

4
CadentOrange

ここにいくつかのオプションがあります。最も簡単な方法は、CPU使用率が高い場合はProcess Explorerです。それ以外の場合は、ProcessMonitorでグラフを確認することをお勧めします。最も可能性の高い原因はバックアップまたは更新のいずれかであると思われるので、それらがいつスケジュールされているかを確認することをお勧めします。タスクスケジューラは、タスクが最後に実行された日時を表示します。

跡形もなく

  • Process Explorer 、プロセスによって消費されるCPUサイクルを確認してください。

イベントに基づく

  • ProcDump CPU使用率が高いなどに基づいて、ダンプファイルを自動的に作成できます。

    ダンプを持つことの利点は、開発者が実際に WinDBGでデバッグする ことができることです。

痕跡あり

  • プロセスモニター 、多くの履歴を保持し、プロファイリングイベントのみをログに記録するように設定します。

    1. [オプション]で、履歴の深さを設定し、プロファイリングイベントの生成をオンにすることができます。

    2. 次に、I/O、レジストリ、およびネットワークボタンを無効にします。

  • Windows Performance Toolkit XPerfがあり、高度なトレースを取得できます。

    これは初めて難しいかもしれないので、最初にProcessMonitorを試してみることをお勧めします...

7
Tamara Wijsman