Procedura: connettere il profiler a un'applicazione .NET Framework autonoma e raccogliere statistiche dell'applicazione tramite la riga di comando
In questo argomento viene illustrato come utilizzare gli strumenti da riga di comando disponibili negli strumenti di profilatura di Visual Studio per connettere il profiler a un'applicazione (client) autonoma .NET Framework in esecuzione e raccogliere statistiche sulle prestazioni tramite il metodo di campionamento.
[!NOTA]
Le funzioni di sicurezza avanzate in Windows 8 e Windows Server 2012 necessarie modifiche significative in modo che il profiler di Visual Studio consente di raccogliere dati su queste piattaforme.Le applicazioni di archivio di Windows richiedono nuove tecniche di raccolta.Vedere Profilatura delle applicazioni Windows 8 e Windows Server 2012.
Gli strumenti da riga di comando degli strumenti di profilatura sono contenuti nella sottodirectory \Team Tools\Performance Tools della directory di installazione di Visual Studio.Nei computer a 64 bit gli strumenti sono disponibili nelle versioni a 32 e 64 bit.Per utilizzare gli strumenti da riga di comando del profiler, è necessario aggiungere il percorso degli strumenti alla variabile di ambiente PATH della finestra Prompt dei comandi oppure aggiungerlo al comando stesso.Per ulteriori informazioni, vedere Specifica del percorso degli strumenti da riga di comando degli strumenti di profilatura.
Aggiungere dati di interazione tra livelli a un'esecuzione del profilo richiede le procedure specifiche con gli strumenti di profilatura della riga di comando.Vedere Aggiunta di dati di interazione tra livelli dalla riga di comando.
Per raccogliere dati di prestazioni da un'applicazione .NET Framework, è necessario inizializzare le variabili di ambiente appropriate prima dell'avvio dell'applicazione di destinazione.Quando il profiler è connesso all'applicazione, è possibile sospendere e riprendere la raccolta dei dati.
Per terminare una sessione di profilo, è necessario che il profiler non sia più connesso all'applicazione e che venga arrestato in modo esplicito.Nella maggior parte dei casi, è consigliabile cancellare le variabili di ambiente di profilo alla fine di una sessione di profilo.
Connessione del profiler
Per connettere il profiler a un'applicazione .NET Framework in esecuzione
Aprire una finestra del prompt dei comandi.
Inizializzare le variabili di ambiente di profilo.Tipo:
VSPerfClrEnv /sampleon [/samplelineoff]
- L'opzione /samplelineoff disabilita la raccolta dei dati del numero di riga del codice sorgente.
Avviare il profiler.Tipo:
**VSPerfCmd /start:sample /output:**OutputFile [Options]
L'opzione /start:sample consente di inizializzare il profiler.
L'opzione /output**:**OutputFile è obbligatoria con /start.OutputFile specifica il nome e il percorso del file dei dati di profilo (vsp).
È possibile utilizzare qualsiasi opzione riportata di seguito con l'opzione /start:sample.
Opzione
Descrizione
/user:[Domain\]UserName
Specifica il dominio e il nome utente facoltativi dell'account proprietario del processo di profilo.Questa opzione è obbligatoria solo se l'applicazione profilata è stata avviata come utente diverso dall'utente connesso.
Abilita il profilo dei processi in altre sessioni di accesso.È possibile specificare /CS come abbreviazione per /crosssession.Questa opzione è obbligatoria se l'applicazione è in esecuzione in una sessione diversa.
/wincounter:WinCounterPath
Specifica un contatore delle prestazioni Windows di cui raccogliere i dati durante il profilo.
/automark:Interval
Utilizzare unicamente con /wincounter.Specifica il numero di millisecondi tra gli eventi di raccolta dati del contatore delle prestazioni Windows.Il valore predefinito è 500 ms.
/events:Config
Specifica un evento Traccia eventi per Windows (ETW) di cui raccogliere i dati durante il profilo.Gli eventi ETW vengono raccolti in un file separato con estensione etl.
Se necessario, avviare l'applicazione di destinazione nel modo usuale.
Connettere il profiler all'applicazione di destinazione.Tipo:
VSPerfCmd /attach:{PID|ProcessName} [Sample Event] [**/targetclr:**Version]
PID specifica l'ID processo dell'applicazione di destinazione.ProcessName specifica il nome del processo.Si noti che se si specifica che sono in esecuzione ProcessName e più processi con lo stesso nome, i risultati sono imprevedibili.È possibile visualizzare gli ID processo di tutti i processi in esecuzione in Gestione attività di Windows.
/targetclr**:**Version specifica la versione del Common Language Runtime (CLR) da profilare quando vengono caricate più versioni del runtime in un'applicazione.Opzionale.
Per impostazione predefinita, i dati di prestazioni vengono campionati ogni 10.000.000 cicli di clock del processore non interrotti, ovverocirca una volta ogni 10 secondi su un processore da 1 GHz.È possibile specificare una delle opzioni seguenti per modificare l'intervallo dei cicli di clock o per specificare un evento di campionamento diverso./targetclr**:**Version specifica la versione di Common Language Runtime (CLR) da profilare quando più di una versione del runtime è caricata in un'applicazione.Opzionale.
Evento di campionamento
Descrizione
/timer:Interval
Imposta l'intervallo di campionamento sul numero di cicli di clock non interrotti specificato da Interval.
/pf [:Interval]
Imposta l'evento di campionamento sugli errori di pagina.Se si specifica Interval, imposta il numero di errori di pagina tra campioni.Il valore predefinito è 10.
/sys [:Interval]
Imposta l'evento di campionamento sulle chiamate di sistema dal processo al kernel del sistema operativo (syscall).Se si specifica Interval, imposta il numero di chiamate tra campioni.Il valore predefinito è 10.
/counter:Config
Imposta l'evento e l'intervallo di campionamento sul contatore delle prestazioni del processore e sull'intervallo specificati in Config.
Controllo della raccolta di dati
Quando l'applicazione di destinazione è in esecuzione, è possibile controllare la raccolta dei dati avviando e interrompendo la scrittura dei dati nel file dei dati del profiler tramite le opzioni di VSPerfCmd.exe.Controllando la raccolta dei dati, è possibile raccogliere dati per una parte specifica dell'esecuzione del programma, ad esempio l'avvio o l'arresto dell'applicazione.
Per avviare e interrompere la raccolta dei dati
Le coppie di opzioni seguenti avviano e interrompono la raccolta dei dati.Specificare ogni opzione in una riga di comando separata.È possibile attivare e disattivare più volte la raccolta dei dati.
Opzione
Descrizione
Avvia (/globalon) o interrompe (/globaloff) la raccolta dei dati per tutti i processi.
/processon:PID/processoff:PID
Avvia (/processon) o interrompe (/processoff) la raccolta dei dati per il processo specificato da PID.
/attach avvia la raccolta di dati per il processo specificato da PID o dal nome del processo (ProcName)./detach interrompe la raccolta di dati per il processo specificato o per tutti i processi se non è specificato un processo particolare.
È inoltre possibile utilizzare l'opzione VSPerfCmd.exe/mark per inserire un contrassegno di profilo nel file di dati.Il comando /mark aggiunge un identificatore, un timestamp e una stringa di testo facoltativa definita dall'utente.I contrassegni possono essere utilizzati per filtrare i dati nelle visualizzazioni dati e nei rapporti del profiler.
Fine della sessione di profilo
Per terminare una sessione di profilo, è necessario che il profiler non sia più connesso a tutti i processi profilati e che venga arrestato in modo esplicito.È possibile disconnettere il profiler da un'applicazione profilata con il metodo di campionamento chiudendo l'applicazione o richiamando l'opzione VSPerfCmd /detach.Chiamare quindi l'opzione VSPerfCmd /shutdown per disattivare il profiler e chiudere il file dei dati di profilo.Il comando VSPerfClrEnv /off cancella le variabili di ambiente di profilo.
Per terminare una sessione di profilo
Effettuare una delle operazioni seguenti per disconnettere il profiler dall'applicazione di destinazione:
Digitare VSPerfCmd /detach
In alternativa
Chiudere l'applicazione di destinazione.
Arrestare il profiler.Tipo:
VSPerfCmd/shutdown
(Facoltativo) Cancellare le variabili di ambiente di profilo.Tipo:
VSPerfClrEnv /off
Vedere anche
Concetti
Profilatura della riga di comando di applicazioni autonome
Altre risorse
Visualizzazioni dei dati del metodo di campionamento del profiler