方法: コマンド ラインを使用してプロファイラーをネイティブ サービスにアタッチし、同時実行データを収集する
ここでは、Visual Studio プロファイリング ツールのコマンド ライン ツールを使用して、プロファイラーをネイティブ (C/C++) サービスにアタッチし、サンプリング メソッドによってプロセス データおよびスレッド同時実行データを収集する方法について説明します。
[!メモ]
Windows 8 のセキュリティは強化された機能および Windows Server 2012 は、Visual Studio のプロファイラーがこれらのプラットフォームのデータを収集する方法に大きな変更されました。Windows ストア apps は、新しいコレクション手法が必要です。「Windows 8 および Windows Server 2012 アプリケーションのプロファイリング」を参照してください。
[!メモ]
プロファイリング ツールのコマンド ライン ツールは、Visual Studio インストール ディレクトリの \Team Tools\Performance Tools サブディレクトリにあります。64 ビット コンピューター上では、64 ビット バージョンのツールと 32 ビット バージョンのツールの両方を使用できます。コマンド プロンプトでプロファイラーを使用するには、コマンド プロンプト ウィンドウの PATH 環境変数またはコマンド自体にツールのパスを追加します。詳細については、「プロファイル ツールのコマンド ライン ツールへのパスの指定」を参照してください。
プロファイラーをサービスにアタッチしている間はデータ収集を一時停止し、完了後に再開できます。プロファイル セッションを終了するには、サービスへのプロファイラーのアタッチを解除し、プロファイラーを明示的に終了する必要があります。
プロファイラーのアタッチ
プロファイラーをネイティブ サービスにアタッチするには、VSPerfCmd の /start オプションおよび /attach オプションを使用して、プロファイラーを初期化し、対象アプリケーションにアタッチします。/start と /attach、およびそれぞれのオプションは、同じコマンド ライン上に指定できます。/globaloff オプションを追加して、対象アプリケーションの起動時にデータ収集を一時停止することもできます。その後、/globalon を使用してデータの収集を開始します。
プロファイラーをネイティブ サービスにアタッチするには
サービスが実行されていない場合は、開始します。
コマンド プロンプトで次のコマンドを入力してプロファイラーを開始します。
VSPerfCmd/start:concurrency **/output:**OutputFile [Options]
- /start には /output**:**OutputFile オプションを指定する必要があります。OutputFile には、プロファイル データ (.vsp) ファイルの名前と場所を指定します。
/start オプションには次の表の任意のオプションを指定できます。
[!メモ]
ほとんどのサービスで /user および /crosssession オプションが必要です。
オプション
説明
/user:[Domain\]UserName
プロファイラーへのアクセスを許可するアカウントのオプションのドメインとユーザー名を指定します。
他のログオン セッションにおけるプロセスのプロファイリングを有効にします。
/wincounter:WinCounterPath
プロファイリング実行中に収集する Windows パフォーマンス カウンターを指定します。
/automark:Interval
/wincounter と共にのみ使用します。Windows パフォーマンス カウンター収集イベントの間隔をミリ秒単位で指定します。既定値は 500 です。
/events:Config
プロファイリング実行中に収集する ETW (Event Tracing for Windows) イベントを指定します。ETW イベントは独立した (.etl) ファイルに収集されます。
コマンド プロンプトで次のコマンドを入力して、プロファイラーをサービスにアタッチします。
**VSPerfCmd /attach:**PID
PID には、対象アプリケーションのプロセス ID またはプロセス名を指定します。Windows タスク マネージャーで、実行中のすべてのプロセスのプロセス ID を参照できます。
データ収集の制御
対象アプリケーションの実行中は、VSPerfCmd.exe のオプションを使用してファイルへのデータ書き込みを開始および停止することにより、データ収集を制御できます。データ収集を制御することにより、アプリケーションの起動や終了など、プログラム実行の特定部分のデータを収集できます。
データ収集を開始および停止するには
次の表に示すオプションの組み合わせにより、データ収集を開始および停止します。個別のコマンド ラインで各オプションを指定します。データ収集のオンとオフは複数回切り替えることができます。
オプション
説明
すべてのプロセスのデータ収集を開始 (/globalon) または停止 (/globaloff) します。
/processon:PID/processoff:PID
プロセス ID (PID) で指定されたプロセスのデータ収集を開始 (/processon) または停止 (/processoff) します。
/attach は、プロセス ID (PID) またはプロセス名 (ProcName) で指定したプロセスのデータ収集を開始します。/detach は、指定されたプロセスのデータ収集を停止します。プロセスが指定されていない場合は、すべてのプロセスのデータ収集を停止します。
VSPerfCmd.exe/mark オプションを使用して、データ ファイルにプロファイル マークを挿入することもできます。/mark コマンドは、ID、タイム スタンプ、およびオプションのユーザー定義文字列を追加します。マークは、プロファイラー レポートおよびデータ ビューでデータをフィルター処理するために使用できます。
プロファイル セッションの終了
プロファイル セッションを終了するには、プロファイラーがデータ収集を停止している必要があります。サービスを停止するか VSPerfCmd /detach オプションを呼び出すことによって、同時実行メソッドを使用してプロファイリングが実行されているネイティブ サービスからのデータ収集を停止できます。次に、VSPerfCmd /shutdown オプションを呼び出して、プロファイラーをオフにし、プロファイル データ ファイルを閉じます。
プロファイル セッションを終了するには
サービスを停止するか、コマンド プロンプトで次のコマンドを入力し、対象のアプリケーションからプロファイラーをデタッチします。
「VSPerfCmd /detach」と入力します。
コマンド プロンプトに次のコマンドを入力し、プロファイラーを終了します。
VSPerfCmd /shutdown