Condividi tramite


Procedura: connettere il profiler a un'applicazione Web ASP.NET per raccogliere dati di memoria tramite la riga di comando

In questo argomento viene descritto come utilizzare gli strumenti da riga di comando disponibili negli strumenti di profilatura di Visual Studio per connettere il profiler a un'applicazione Web ASP.NET e raccogliere i dati relativi al numero e alla dimensione delle allocazioni della memoria .NET Framework.È inoltre possibile raccogliere dati sulla durata degli oggetti di memoria .NET Framework.

[!NOTA]

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.

Per raccogliere i dati delle prestazioni da un'applicazione Web ASP.NET, è necessario utilizzare lo strumento VSPerfCLREnv.cmd per inizializzare le variabili di ambiente appropriate nel computer che ospita l'applicazione Web ASP.NET.È quindi necessario riavviare il computer per configurare il server Web per la profilatura.

Utilizzare quindi lo strumento VSPerfCmd.exe per connettere il profiler al processo di lavoro ASP.NET che ospita il sito Web.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.

Connessione del profiler

Per connettere il profiler a un'applicazione Web ASP.NET

  1. Aprire una finestra del prompt dei comandi.

  2. Inizializzare le variabili di ambiente di profilo.Tipo:

    VSPerfClrEnv {/globalsamplegc | /globalsamplegclife} [/samplelineoff]

    • Le opzioni /globalsamplegc e /globalsamplegclife specificano il tipo di dati di memoria da raccogliere.

      Specificare una sola delle seguenti opzioni.

      Opzione

      Descrizione

      /globalsamplegc

      Abilita la raccolta dei dati sull'allocazione di memoria.

      /globalsamplegclife

      Abilita la raccolta dei dati relativi sia all'allocazione della memoria che alla durata degli oggetti.

    • L'opzione /samplelineoff disabilita l'assegnazione dei dati raccolti a righe specifiche del codice sorgente.Se viene specificata questa opzione, i dati vengono assegnati a livello di funzione.

  3. Riavviare il computer per impostare la nuova configurazione dell'ambiente.

  4. Aprire una finestra del prompt dei comandi.Se necessario, impostare la variabile di ambiente del percorso del profiler.

  5. 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.

    [!NOTA]

    Le opzioni /user e /crosssession sono in genere obbligatorie per le applicazioni ASP.NET.

    Opzione

    Descrizione

    /user:[Domain\]UserName

    Specifica il dominio e il nome utente dell'account proprietario del processo di lavoro ASP.NET.Questa opzione è obbligatoria se il processo è in esecuzione come un utente diverso dall'utente connesso.Il proprietario del processo è elencato nella colonna Nome utente della scheda Processi di Gestione attività di Windows.

    /crosssession

    Abilita il profilo dei processi in altre sessioni di accesso.Questa opzione è obbligatoria se l'applicazione ASP.NET è in esecuzione in una sessione diversa.L'identificatore di sessione è elencato nella colonna ID sessione della scheda Processi di Gestione attività di Windows.È possibile specificare /CS come abbreviazione per /crosssession.

    /waitstart [:Interval]

    Specifica il numero di secondi di attesa prima che il profiler venga inizializzato prima che venga restituito un errore.Se Interval non è specificato, il profiler attenderà un periodo di tempo indefinito.Per impostazione predefinita, /start viene immediatamente restituito.

    /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.

  6. Avviare l'applicazione Web ASP.NET nel modo usuale.

  7. Connettere il profiler a un processo di lavoro ASP.NET.Tipo:

    VSPerfCmd /attach:{PID|ProcName} [/targetclr**:**Version]

    • L'ID processo (PID) specifica l'ID o il nome del processo di lavoro ASP.NET.È possibile visualizzare gli ID processo di tutti i processi in esecuzione in Gestione attività di Windows.

    • **/targetclr:**Version specifica la versione di Common Language Runtime (CLR) da profilare quando più di una versione del runtime è caricata in un'applicazione.

Controllo della raccolta di dati

Quando l'applicazione è 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 seguenti di opzioni di VSPerfCmd 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

    /globalon /globaloff

    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 dal PID.

    /attach:{PID|ProcName} /detach[:{PID|:ProcName}]

    /attach avvia la raccolta di dati per il processo specificato dall'ID processo o dal nome processo./detach interrompe la raccolta di dati per il processo specificato o per tutti i processi se non è specificato un processo particolare.

Fine della sessione di profilo

Per terminare una sessione di profilo, è necessario che il profiler non sia più connesso all'applicazione Web.È possibile interrompere la raccolta dei dati da un'applicazione profilata con il metodo di campionamento riavviando il processo di lavoro ASP.NET o chiamando l'opzione VSPerfCmd /detach.Chiamare quindi l'opzione VSPerfCmd /shutdown per disattivare il profiler e chiudere il file dei dati di profilatura.Il comando VSPerfClrEnv /globaloff cancella le variabili di ambiente di profilo, ma la configurazione del sistema non viene reimpostata finché non viene riavviato il computer.

Per terminare una sessione di profilo

  1. Effettuare una delle operazioni seguenti per disconnettere il profiler dall'applicazione di destinazione:

    • Digitare VSPerfCmd /detach

      In alternativa

    • Chiudere il processo di lavoro ASP.NET.Tipo:

    IISReset /stop

  2. Arrestare il profiler.Tipo:

    VSPerfCmd /shutdown

  3. (Facoltativo) Cancellare le variabili di ambiente di profilo.Tipo:

    VSPerfCmd /globaloff

  4. Riavviare il computer.Se necessario, riavviare Internet Information Services (IIS).Tipo:

    IISReset /start

Vedere anche

Concetti

Profilatura tramite riga di comando di applicazioni Web ASP.NET

Altre risorse

Visualizzazioni dei dati di memoria .NET degli strumenti di profilatura