Quando sviluppiamo applicativi .NET Core abbiamo disposizione un'ottima infrastruttura di logging utilizzata da ASP.NET Core stesso, ma che possiamo sfruttare anche noi. Logging strutturato, categorie, filtri e livelli ci permettono di essere mirati e cercare immediatamente le informazioni delle quali abbiamo bisogno.
Quando carichiamo il nostro applicativo su Azure App Service, però, il logging che effettuiamo non è visibile. I provider predefiniti, come su console, non vengono catturati a meno che non installiamo Application Insights, direttamente sul progetto, o direttamente dal portale tramite estensioni.
In alternativa, il portale stesso mette a disposizione la cattura del logging su file o su storage e al tempo stesso di vedere lo streaming live dell'output. Per sfruttare tutto questo dobbiamo prima di tutto aggiungere un nuovo provider direttamente in Program.cs come nell'esempio seguente.
public static IHostBuilder CreateHostBuilder(string[] args) => Host.CreateDefaultBuilder(args) .ConfigureLogging(logging => logging.AddAzureWebAppDiagnostics()) .ConfigureWebHostDefaults(webBuilder => { webBuilder.UseStartup<Startup>(); });
L'extension method AddAzureWebAppDiagnostics è disponibile installando il pacchetto NuGet Microsoft.Extensions.Logging.AzureAppServices e non comporta alcun problema quando siamo in locale. Quando il nostro applicativo gira su Azure, invece, ci permette di accedere alla sezione App Service logs e abilitare il log con il rispettivo livello da mostrare.
Da questo momento il log verrà salvato su disco per un massimo di 12 ore, ma al tempo stesso potremo vedere visualizzato l'output andando nella sezione Log stream.
Ricordiamo che attraverso la sezione application settings e con le chiavi Logging:Default e relative categorie, possiamo anche decidere quale categorie mostrare e con quale livello, in modo da poter visualizzare nello streaming solo lo stretto necessario.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Effettuare il deploy di immagini solo da container registry approvati in Kubernetes
Eseguire le GitHub Actions offline
Potenziare Azure AI Search con la ricerca vettoriale
Accesso sicuro ai secrets attraverso i file in Azure Container Apps
Sfruttare lo stream rendering per le pagine statiche di Blazor 8
Utilizzare Model as a Service su Microsoft Azure
Effettuare chiamate con versioning da Blazor ad ASP.NET Core
Creare gruppi di client per Event Grid MQTT
Ottimizzare la latenza in Blazor 8 tramite InteractiveAuto render mode
Eseguire attività basate su eventi con Azure Container Jobs
Eseguire query manipolando liste di tipi semplici con Entity Framework Core
I più letti di oggi
- Miglioramenti nelle performance di Angular 16
- Ottimizzare le performance delle collection con le classi FrozenSet e FrozenDictionary
- HTML5 con CSS e JavaScript
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Ottimizzazione dei block template in Angular 17
- Disabilitare automaticamente un workflow di GitHub (parte 2)