Nello script #556 abbiamo introdotto il metodo LogTo per loggare le informazioni. In quello script abbiamo visto come inviare qualunque log emesso da Entity Framework Core verso output come la console e la finestra di output in Visual Studio. Entity Framework Core emette tantissime informazioni di logging che spesso non sono importanti durante lo sviluppo. Una delle cose più comuni in fase di sviluppo è visualizzare il codice SQL che viene generato sia in fase di lettura che in fase di scrittura e non altre informazioni. Per filtrare i messaggi di log che vengono inviati alla action passata in input al metodo LogTo possiamo ricorrere agli overload di questo metodo.
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
//overload 1
optionsBuilder.LogTo(
Debug.WriteLine,
new[] { RelationalEventId.CommandExecuted },
LogLevel.Debug);
//overload 2
optionsBuilder.LogTo(Debug.WriteLine,
(e, l) => l == LogLevel.Debug && e == RelationalEventId.CommandExecuted);
}In questo esempio possiamo visualizzare i due overload che permettono di scegliere le condizioni in base alle quali la action di log deve essere invocata.
Nel primo overload passiamo come secondo parametro un array di eventi che corrisponde ai tipi di evento per i quali vogliamo che la action di log venga invocata. Come tezo parametro passiamo il livello di debug necessario per invocare la action.
Nel secondo overload come secondo parametro specifichiamo una funzione che prende in input tipo di evento di log e il livello di log dell'evento e specifica una condizione in base alla quale invocare o meno la action di log.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Proteggere l'endpoint dell'agente A2A delle Logic App
Arricchire l'interfaccia di .NET Aspire
Utilizzare @property per animare nativamente un oggetto HTML tramite CSS
Semplificare i deployment con le label in Azure Container App
Configurare automaticamente un webhook in Azure DevOps
Le cron expression di un workflow di GitHub
Ciclo di vita risorse con .NET Aspire
Self-healing degli unit test con Copilot in GitHub
Evitare la compressione degli artefatti in un workflow di GitHub
Recuperare gli audit log in Azure DevOps
Gestione delle issue type con GitHub
Interazione con ReconnectModal in Blazor




