Configurare la versione per diagnosticare i problemi dopo la distribuzione
Per diagnosticare i problemi nell'app Web ASP.NET dopo la distribuzione usando IntelliTrace, includere le informazioni di compilazione nella versione per consentire a Visual Studio di trovare automaticamente i file di origine corretti e i file di simboli necessari per il debug del log IntelliTrace.
Se si usa Microsoft Monitoring Agent per controllare IntelliTrace, è necessario configurare il monitoraggio delle prestazioni delle applicazioni nel server Web. In questo modo vengono registrati gli eventi di diagnostica durante l'esecuzione dell'applicazione e vengono salvati gli eventi nel file di log IntelliTrace. È quindi possibile esaminare gli eventi in Visual Studio Ultimate, passare al codice nel punto in cui si è verificato l'evento, esaminare i valori registrati in quel momento e spostarsi avanti o indietro lungo il codice che è stato eseguito. Dopo aver trovato e risolto il problema, ripetere il ciclo per compilare, rilasciare e monitorare la versione per risolvere eventuali problemi futuri più tempestivamente e rapidamente.
Sono necessari:
Visual Studio 2013 o Team Foundation Server 2013, 2012 o 2010 per configurare la build
Microsoft Monitoring Agent per monitorare i dati di diagnostica della registrazione dell'applicazione
Visual Studio Ultimate 2013 per esaminare i dati diagnostici ed eseguire il debug del codice con IntelliTrace
Passaggio 1. Includere le informazioni sulla build nella versione
Configurare il processo di compilazione per creare un manifesto di compilazione (file BuildInfo.config) per il progetto Web e includere il manifesto nella versione. Il manifesto contiene informazioni relative al progetto, al controllo del codice sorgente e al sistema di compilazione usati per creare una specifica build. Con queste informazioni, è possibile trovare tramite Visual Studio l'origine e i simboli corrispondenti, dopo aver aperto il log IntelliTrace per esaminare gli eventi registrati.
Creare il manifesto di compilazione per una compilazione automatica con Team Foundation Server
Seguire questi passaggi se si usa il controllo della versione di Team Foundation o Git.
Team Foundation Server 2013
Configurare la definizione di compilazione per aggiungere le posizioni di origine, compilazione e simboli al manifesto di compilazione (file BuildInfo.config). Team Foundation Build crea automaticamente questo file e lo inserisce nella cartella di output del progetto.
Modificare la definizione di compilazione o creare una nuova definizione di compilazione.
Scegliere il modello predefinito (TfvcTemplate.12.xaml) o il proprio modello personalizzato.
Specificare dove salvare il file dei simboli (PDB) in modo da indicizzare automaticamente l'origine.
Se si usa un modello personalizzato, verificare che disponga di un'attività per l'indicizzazione dell'origine. In seguito verrà aggiunto un argomento MSBuild per specificare il percorso in cui salvare i file dei simboli.
Per altre informazioni sui simboli, vedere Pubblicare i dati dei simboli.
Aggiungere questo argomento MSBuild per inserire i percorsi di TFS e simboli nel file manifesto di compilazione:
/p:IncludeServerNameInBuildInfo=True
Chiunque possa aver accesso al server Web può visualizzare questi percorsi nel manifesto di compilazione. Assicurarsi che il server di origine sia sicuro.
Se si usa un modello personalizzato, aggiungere questo argomento MSBuild per specificare dove salvare il file dei simboli:
/p:BuildSymbolStorePath=<percorso dei simboli>
Aggiungere le righe seguenti al file di progetto Web (estensione csproj o vbproj):
<!-- Import the targets file. Change the folder location as necessary. --> <Import Project=""$(MSBuildExtensionsPath)\Microsoft\VisualStudio\v$(VisualStudioVersion)\BuildInfo\Microsoft.VisualStudio.ReleaseManagement.BuildInfo.targets" />
Eseguire una nuova compilazione.
Passaggio 2: Rilasciare l'applicazione
Team Foundation Server 2012 o 2010
Seguire questi passaggi per creare automaticamente il manifesto di compilazione (file BuildInfo.config) per il progetto e inserire il file nella cartella di output del progetto. Il file viene visualizzato come "ProjectName.BuildInfo.config" nella cartella di output ma viene rinominato "BuildInfo.config" nella cartella di distribuzione dopo la pubblicazione dell'applicazione.
Installare Visual Studio 2013 (qualsiasi edizione) nel server Team Foundation Build.
Nella definizione della compilazione specificare il percorso in cui salvare i simboli in modo da indicizzare automaticamente l'origine.
Se si usa un modello personalizzato, verificare che disponga di un'attività per l'indicizzazione dell'origine.
Aggiungere gli argomenti MSBuild alla definizione della compilazione:
/p:VisualStudioVersion=12.0
/p:MSBuildAssemblyVersion=12.0
/tv:12.0
/p:IncludeServerNameInBuildInfo=True
/p:BuildSymbolStorePath=<percorso dei simboli>
Eseguire una nuova compilazione.
Passaggio 2: Rilasciare l'applicazione
Creare il manifesto di compilazione per una compilazione manuale usando Visual Studio 2013
Seguire questi passaggi per creare automaticamente il manifesto di compilazione (file BuildInfo.config) per il progetto e inserire il file nella cartella di output del progetto. Il file viene visualizzato come "ProjectName.BuildInfo.config" nella cartella di output ma viene rinominato "BuildInfo.config" nella cartella di distribuzione dopo la pubblicazione dell'applicazione.
Scaricare il progetto Web in Esplora soluzioni.
Aprire il file di progetto (estensione .csproj o .vbproj). Aggiungere queste righe:
<!-- **************************************************** --> <!-- Build info --> <PropertyGroup> <!-- Generate the BuildInfo.config file --> <GenerateBuildInfoConfigFile>True</GenerateBuildInfoConfigFile> <!-- Include server name in build info --> <IncludeServerNameInBuildInfo>True</IncludeServerNameInBuildInfo> <!-- Include the symbols path so Visual Studio can find the matching deployed code when you start debugging. --> <BuildSymbolStorePath><path to symbols></BuildSymbolStorePath> </PropertyGroup> <!-- **************************************************** -->
Archiviare il file di progetto aggiornato.
Eseguire una nuova compilazione.
Passaggio 2: Rilasciare l'applicazione
Creare il manifesto di compilazione per una compilazione manuale con MSBuild.exe
Aggiungere gli argomenti di compilazione quando si eseguirà una compilazione:
/p:GenerateBuildInfoConfigFile=True
/p:IncludeServerNameInBuildInfo=True
/p:BuildSymbolStorePath=<percorso dei simboli>
Passaggio 2: Rilasciare l'applicazione
Se si usa il pacchetto di Web.Deploy creato dal processo di compilazione per distribuire l'applicazione, il manifesto di compilazione viene rinominato automaticamente da "ProjectName.BuildInfo.config" a "BuildInfo.config" e viene inserito nella stessa cartella del file Web.config dell'applicazione, nel server Web.
Se vengono usati altri metodi per distribuire l'applicazione, assicurarsi che il manifesto di compilazione sia rinominato da "ProjectName.BuildInfo.config" a "BuildInfo.config" inserito nella stessa cartella del file Web.config dell'applicazione, nel server Web.
Passaggio 3. Monitorare l'applicazione
Impostare il monitoraggio delle prestazioni dell'applicazione sul server Web in modo tale da poter monitorare l'insorgere di problemi nell'applicazione, registrare eventi diagnostici e salvare tali eventi nel file di log IntelliTrace. Vedere la pagina relativa al monitoraggio della versione per il rilevamento di problemi di distribuzione.
Passaggio 4. Individuare il problema
È necessario disporre di Visual Studio Ultimate 2013 sul computer di sviluppo o un altro computer, per esaminare gli eventi registrati ed eseguire il debug del codice con IntelliTrace. È inoltre possibile usare strumenti come CodeLens, mappe del debugger e mappe del codice per diagnosticare il problema.
Aprire il log IntelliTrace e la soluzione corrispondente
Aprire il log IntelliTrace (file .iTrace) da Visual Studio Ultimate 2013. In alternativa fare doppio clic sul file in Visual Studio Ultimate 2013 nello stesso computer.
Scegliere Apri soluzione per fare in modo che in Visual Studio venga automaticamente aperta la soluzione o il progetto corrispondente, se il progetto non è stato compilato come parte di una soluzione. Nel log IntelliTrace mancano le informazioni sull'applicazione distribuita. Per quale motivo? Che cosa si può fare?
Visual Studio esegue automaticamente lo shelving di qualsiasi modifica in sospeso all'apertura della soluzione o del progetto corrispondente. Per ottenere ulteriori dettagli su questo shelveset, aprire la finestra Output o Team Explorer.
Prima di apportare modifiche, verificare di disporre dell'origine corretta. Se si ricorre al branching, è possibile che il branch su cui si sta lavorando sia diverso rispetto a quello in cui Visual Studio cerca l'origine corrispondente, ad esempio il branch della versione.
Se è presente un'area di lavoro mappata per questa soluzione o questo progetto, Visual Studio la seleziona per inserirvi l'origine trovata.
In caso contrario, scegliere un'altra area di lavoro già mappata o crearne una nuova. Visual Studio esegue il mapping dell'intero branch a questa area di lavoro.
Per creare un'area di lavoro con mapping specifici o un nome diverso dal nome del computer, scegliere Gestisci.
Perché secondo Visual Studio l'area di lavoro selezionata è inadatta?
Perché non è possibile continuare finché non si sceglie una raccolta team o una raccolta diversa?
Identificare un problema di prestazioni
In Violazioni prestazioni esaminare gli eventi di prestazioni registrati, i relativi tempi di esecuzione totali e altre informazioni sugli eventi. Esaminare ulteriori dettagli sui metodi chiamati durante un evento di prestazioni specifico.
È inoltre sufficiente fare doppio clic sull'evento.
Nella pagina dell'evento rivedere i tempi di esecuzione per queste chiamate. Cercare una chiamata lenta nell'albero di esecuzione.
Le chiamate più lente vengono visualizzate nella specifica sezione in caso di più chiamate, annidate o meno.
Espandere tale chiamata per rivedere tutte le chiamate e i valori annidati registrati in quel momento. Avviare quindi il debug dalla chiamata.
È inoltre sufficiente fare doppio clic sulla chiamata.
Se il metodo è incluso nel codice dell'applicazione, Visual Studio passa a tale metodo.
È possibile esaminare altri valori registrati, lo stack di chiamate, eseguire un'istruzione alla volta nel codice o usare la finestra IntelliTrace per spostarsi in avanti o indietro tra gli altri metodi chiamati durante questo evento di prestazioni. Che cosa sono gli altri eventi e informazioni riportati nel log IntelliTrace? Quali altre operazioni posso eseguire da qui? Si vogliono maggiori informazioni sugli eventi delle prestazioni?
Diagnosticare un'eccezione
In Dati eccezione esaminare gli eventi di eccezione registrati, i relativi tipi, i messaggi e il momento in cui si sono verificate le eccezioni. Per esaminare il codice in dettaglio, avviare il debug dall'evento più recente in un gruppo di eccezioni.
È inoltre sufficiente fare doppio clic sull'evento.
Se l'eccezione si è verificata nel codice dell'applicazione, Visual Studio passa a questa posizione.
È possibile esaminare altri valori registrati, lo stack di chiamate o usare la finestra IntelliTrace per spostarsi in avanti o indietro tra gli altri eventi registrati, il codice correlato e i valori registrati in questi specifici momenti. Che cosa sono gli altri eventi e informazioni riportati nel log IntelliTrace?
Quali altre operazioni posso eseguire da qui?
Ottenere altre informazioni su questo codice. Per trovare riferimenti a questo codice, alla cronologia delle modifiche, a bug, elementi di lavoro, revisioni del codice o unit test correlati senza uscire dall'editor, usare gli indicatori di CodeLens nell'editor
Eseguire il mapping della posizione nel codice durante il debug. Per rilevare visivamente i metodi chiamati durante la sessione di debug, eseguire il mapping dello stack di chiamate.
Domande e risposte
Q: Perché è opportuno includere nella versione informazioni sul progetto, il controllo del codice sorgente, compilazione e simboli?
Visual Studio usa queste informazioni per trovare la soluzione e l'origine corrispondenti alla versione su cui si sta eseguendo il debug. Dopo aver aperto il log IntelliTrace e aver selezionato un evento per avviare il debug, Visual Studio usa simboli per trovare e visualizzare il codice dove si è verificato l'evento. È quindi possibile esaminare i valori registrati e spostarsi in avanti o indietro nell'esecuzione del codice.
Se si usa TFS e queste informazioni non sono presenti nel manifesto di compilazione (file BuildInfo.config), Visual Studio cerca l'origine e i simboli corrispondenti nel TFS attualmente connesso. Se Visual Studio non trova il TFS corretto o l'origine corrispondente, verrà richiesto di scegliere un altro TFS.
D: Nel log IntelliTrace mancano le informazioni sull'applicazione distribuita.Per quale motivo?Che cosa si può fare?
Questo può verificarsi quando la distribuzione viene effettuata dal computer di sviluppo oppure non si è connessi a TFS durante la distribuzione.
Passare alla cartella di distribuzione del progetto.
Trovare e aprire il manifesto di compilazione (file BuildInfo.config).
Assicurarsi che il file contenga le informazioni richieste:
Campo |
Specifica |
---|---|
ProjectName |
Il nome del progetto in Visual Studio. Ad esempio:
|
SourceControl |
Le informazioni sul sistema di controllo del codice sorgente e queste proprietà richieste:
|
Compila |
Informazioni sul sistema di compilazione, "TeamBuild" o "MSBuild" e queste proprietà richieste:
Ad esempio:
|
D: Perché secondo Visual Studio l'area di lavoro selezionata è inadatta?
R: L'area di lavoro selezionata non include mapping tra la cartella del controllo del codice sorgente e una cartella locale. Per creare un mapping per questa area di lavoro, scegliere Gestisci. In caso contrario, scegliere un'area di lavoro già mappata o creare una nuova area di lavoro.
D: Perché non è possibile continuare finché non si sceglie una raccolta team o una raccolta diversa?
R: Questo può verificarsi per uno qualsiasi dei seguenti motivi:
Visual Studio non è connesso a TFS.
In Visual Studio non è stata trovata la soluzione o il progetto nella raccolta del team corrente.
Quando il file manifesto di compilazione (<ProjectName>.BuildInfo.config) non specifica la posizione in cui Visual Studio può individuare l'origine corrispondenza, viene usato il TFS attualmente connesso per identificare la soluzione o il progetto corrispondente. Se la raccolta del team corrente non dispone dell'origine corrispondente, in Visual Studio viene richiesto di connettersi a una raccolta del team diversa.
In Visual Studio non sono stati trovati la soluzione o il progetto nella raccolta specificata dal file manifesto di compilazione (<ProjectName>.BuildInfo.config).
È possibile che il TFS specificato non disponga più dell'origine corrispondente o non esista più, probabilmente perché è stata eseguita la migrazione a un nuovo TFS. Se il TFS specificato non esiste, è possibile che si verifichi il timeout di Visual Studio dopo circa un minuto e viene quindi richiesto di connettersi a una raccolta diversa. Per continuare, connettersi al server TFS corretto.
D: Che cos'è un'area di lavoro?
R: L'area di lavoro consente di archiviare una copia dell'origine per consentire di svilupparla prima di archiviare il lavoro. Se non è già presente un'area di lavoro mappata specificatamente alla soluzione o al progetto trovato, in Visual Studio viene richiesto di scegliere un'area di lavoro disponibile oppure di crearne una nuova con il nome del computer in uso come nome predefinito dell'area di lavoro.
D: Perché viene visualizzato questo messaggio sui simboli non attendibili?
A: Questo messaggio viene visualizzato quando il percorso dei simboli nel file manifesto di compilazione (<ProjectName>.BuildInfo.config) non è incluso nell'elenco di percorsi dei simboli attendibili. È possibile aggiungere il percorso dell'elenco di percorsi di simboli nelle opzioni del debugger.