Procedura dettagliata: filtro dell'output di My.Application.Log
Questa procedura dettagliata illustra come modificare il filtro di log predefinito per l'oggetto My.Application.Log
per stabilire quali informazioni vengono passate dall'oggetto Log
ai listener e quali informazioni vengono scritte dai listener. È possibile modificare il comportamento di registrazione anche dopo la compilazione dell'applicazione, poiché le informazioni di configurazione vengono archiviate nel file di configurazione dell'applicazione.
Introduzione
A ogni messaggio scritto da My.Application.Log
è associato un livello di gravità, che i meccanismi di filtro usano per controllare l'output del log. Questa applicazione di esempio usa i metodi My.Application.Log
per scrivere alcuni messaggi di log con diversi livelli di gravità.
Per compilare l'applicazione di esempio
Aprire un nuovo progetto Applicazione Windows in Visual Basic.
Aggiungere un pulsante denominato Button1 a Form1.
Aggiungere il codice seguente al gestore eventi Click per Button1:
' Activity tracing information My.Application.Log.WriteEntry("Entering Button1_Click", TraceEventType.Start) ' Tracing information My.Application.Log.WriteEntry("In Button1_Click", TraceEventType.Information) ' Create an exception to log. Dim ex As New ApplicationException ' Exception information My.Application.Log.WriteException(ex) ' Activity tracing information My.Application.Log.WriteEntry("Leaving Button1_Click", TraceEventType.Stop)
Eseguire l'applicazione nel debugger.
Premere Button1.
L'applicazione scrive le informazioni seguenti nel file di log e di output di debug dell'applicazione.
DefaultSource Information: 0 : In Button1_Click
DefaultSource Error: 2 : Error in the application.
Chiudere l'applicazione.
Per informazioni su come visualizzare la finestra di output di debug dell'applicazione, vedere Finestra di output. Per informazioni sul percorso del file di log dell'applicazione, vedere Procedura dettagliata: Individuazione della posizione di inserimento delle informazioni con My.Application.Log.
Nota
Per impostazione predefinita, l'applicazione elimina l'output del file di log alla chiusura dell'applicazione.
Nell'esempio precedente la seconda chiamata al metodo WriteEntry e la chiamata al metodo WriteException generano l'output del log, mentre non lo generano la prima e l'ultima chiamata al metodo
WriteEntry
. Questo avviene poiché i livelli di gravità diWriteEntry
eWriteException
sono "Information" ed "Error", entrambi consentiti dal filtro di log predefinito dell'oggettoMy.Application.Log
. Tuttavia, agli eventi con i livelli di gravità "Start" e "Stop" non è consentito creare output di log.
Filtro per tutti i listener di My.Application.Log
L'oggetto My.Application.Log
usa una classe SourceSwitch denominata DefaultSwitch
per stabilire quali messaggi vengono passati dai metodi WriteEntry
e WriteException
ai listener di log. È possibile configurare DefaultSwitch
nel file di configurazione dell'applicazione impostando il relativo valore su uno dei valori di enumerazione di SourceLevels. Per impostazione predefinita, il valore è "Information".
Questa tabella illustra il livello di gravità richiesto al log per la scrittura di un messaggio ai listener, data un'impostazione DefaultSwitch
specifica.
Valore DefaultSwitch | Gravità del messaggio richiesto per l'output |
---|---|
Critical |
Critical |
Error |
Critical oppure Error |
Warning |
Critical , Error o Warning |
Information |
Critical , Error , Warning o Information |
Verbose |
Critical , Error , Warning , Information o Verbose |
ActivityTracing |
Start , Stop , Suspend , Resume o Transfer |
All |
Sono consentiti tutti i messaggi. |
Off |
Tutti i messaggi vengono bloccati. |
Nota
I metodi WriteEntry
e WriteException
hanno entrambi un overload che non specifica un livello di gravità. Il livello di gravità implicito per l'overload di WriteEntry
è "Information" e il livello di gravità implicito per l'overload WriteException
è "Error".
In questa tabella viene illustrato l'output di log dell'esempio precedente: con l'impostazione predefinita "Information" per DefaultSwitch
solo la seconda chiamata al metodo WriteEntry
e la chiamata al WriteException
producono output di log.
Per registrare solo gli eventi di traccia attività
Fare clic con il pulsante destro del mouse su app.config Esplora soluzioni e selezionare Apri.
oppure
Se non è presente alcun file app.config:
Scegliere Aggiungi nuovo elemento dal menu Progetto.
Nella finestra di dialogo Aggiungi nuovo elemento scegliere File di configurazione dell'applicazione.
Fare clic su Aggiungi.
Individuare la sezione
<switches>
nella sezione<system.diagnostics>
all'interno della sezione di primo livello<configuration>
.Trovare l'elemento che consente di aggiungere
DefaultSwitch
alla raccolta di opzioni. Deve essere simile all'elemento seguente:<add name="DefaultSwitch" value="Information" />
Modificare il valore dell'attributo
value
impostandolo su "ActivityTracing".Il contenuto del file app.config dovrebbe essere simile al codice XML seguente.
<?xml version="1.0" encoding="utf-8" ?> <configuration> <system.diagnostics> <sources> <!-- This section configures My.Application.Log --> <source name="DefaultSource" switchName="DefaultSwitch"> <listeners> <add name="FileLog"/> </listeners> </source> </sources> <switches> <add name="DefaultSwitch" value="ActivityTracing" /> </switches> <sharedListeners> <add name="FileLog" type="Microsoft.VisualBasic.Logging.FileLogTraceListener, Microsoft.VisualBasic, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL" initializeData="FileLogWriter"/> </sharedListeners> </system.diagnostics> </configuration>
Eseguire l'applicazione nel debugger.
Premere Button1.
L'applicazione scrive le informazioni seguenti nel file di log e di output di debug dell'applicazione:
DefaultSource Start: 4 : Entering Button1_Click
DefaultSource Stop: 5 : Leaving Button1_Click
Chiudere l'applicazione.
Impostare di nuovo il valore dell'attributo
value
su "Information".Nota
L'impostazione dell'opzione
DefaultSwitch
controlla soloMy.Application.Log
. Non modifica il comportamento delle classi System.Diagnostics.Trace e System.Diagnostics.Debug di .NET.
Filtro individuale per i listener di My.Application.Log
Nell'esempio precedente viene illustrato come modificare il filtro per tutto l'output di My.Application.Log
. Questo esempio illustra come filtrare un singolo listener di log. Per impostazione predefinita, un'applicazione ha due listener che scrivono nell'output di debug dell'applicazione e nel file di log.
Il file di configurazione controlla il comportamento dei listener di log, consentendo a ognuno di essi di avere un filtro, che è simile a un'opzione per My.Application.Log
. Un listener di log genera un messaggio solo se la gravità del messaggio è consentita sia dall'opzione DefaultSwitch
del log, sia dal filtro del listener di log.
In questo esempio viene illustrato come configurare il filtro per un nuovo listener di debug e aggiungerlo all'oggetto Log
. Il listener di debug predefinito deve essere rimosso dall'oggetto Log
in modo che sia chiaro che i messaggi di debug provengono dal nuovo listener di debug.
Per registrare solo gli eventi di traccia attività
Fare clic con il pulsante destro del mouse su app.config in Esplora soluzioni e scegliere Apri.
oppure
Se non è presente alcun file app.config:
Scegliere Aggiungi nuovo elemento dal menu Progetto.
Nella finestra di dialogo Aggiungi nuovo elemento scegliere File di configurazione dell'applicazione.
Fare clic su Aggiungi.
Fare clic con il pulsante destro del mouse su app.config in Esplora soluzioni. Scegliere Apri.
Individuare la sezione
<listeners>
all'interno della sezione<source>
con l'attributoname
"DefaultSource" che si trova nella sezione<sources>
. La sezione<sources>
si trova nella sezione<system.diagnostics>
all'interno della sezione di primo livello<configuration>
.Aggiungere l'elemento seguente alla sezione
<listeners>
:<!-- Remove the default debug listener. --> <remove name="Default"/> <!-- Add a filterable debug listener. --> <add name="NewDefault"/>
Individuare la sezione
<sharedListeners>
nella sezione<system.diagnostics>
all'interno della sezione di primo livello<configuration>
.Aggiungere l'elemento seguente alla sezione
<sharedListeners>
:<add name="NewDefault" type="System.Diagnostics.DefaultTraceListener, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089, processorArchitecture=MSIL"> <filter type="System.Diagnostics.EventTypeFilter" initializeData="Error" /> </add>
Il filtro EventTypeFilter accetta uno dei valori di enumerazione di SourceLevels come proprio attributo
initializeData
.Il contenuto del file app.config dovrebbe essere simile al codice XML seguente.
<?xml version="1.0" encoding="utf-8" ?> <configuration> <system.diagnostics> <sources> <!-- This section configures My.Application.Log --> <source name="DefaultSource" switchName="DefaultSwitch"> <listeners> <add name="FileLog"/> <!-- Remove the default debug listener. --> <remove name="Default"/> <!-- Add a filterable debug listener. --> <add name="NewDefault"/> </listeners> </source> </sources> <switches> <add name="DefaultSwitch" value="Information" /> </switches> <sharedListeners> <add name="FileLog" type="Microsoft.VisualBasic.Logging.FileLogTraceListener, Microsoft.VisualBasic, Version=8.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a, processorArchitecture=MSIL" initializeData="FileLogWriter"/> <add name="NewDefault" type="System.Diagnostics.DefaultTraceListener, System, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089, processorArchitecture=MSIL"> <filter type="System.Diagnostics.EventTypeFilter" initializeData="Error" /> </add> </sharedListeners> </system.diagnostics> </configuration>
Eseguire l'applicazione nel debugger.
Premere Button1.
L'applicazione scrive le informazioni seguenti nel file di log dell'applicazione:
Default Information: 0 : In Button1_Click
Default Error: 2 : Error in the application.
L'applicazione scrive meno informazioni nell'output di debug dell'applicazione perché il filtro è più restrittivo.
Default Error 2 Error
Chiudere l'applicazione.
Per altre informazioni sulla modifica delle impostazioni del log dopo la distribuzione, vedere Utilizzo dei log applicazione.
Vedi anche
- Procedura dettagliata: Individuazione della posizione di inserimento delle informazioni con My.Application.Log
- Procedura dettagliata: Modifica della posizione di inserimento delle informazioni con My.Application.Log
- Procedura dettagliata: Creazione di listener di log personalizzati
- Procedura: Scrivere messaggi di log
- Opzioni di traccia
- Registrazione di informazioni relative all'applicazione