Negli scorsi script ci siamo occupati di Output Cache in ASP.NET Core 7, e abbiamo iniziato ad apprezzarne la flessibilità e semplicità di configurazione. Abbiamo però trascurato un aspetto fondamentale per questo tipo di funzionalità: per quanto tempo una determinata risposta deve rimanere in cache?
Per default, la durata della cache è di un minuto, tuttavia possiamo facilmente modificare questa impostazione all'interno del solito metodo CacheOutput, quando stiamo definendo un endpoint di Minimal API:
app.MapGet("/cacheDemoInline", (string name) => $"Hello, {name}, time is {DateTime.Now.ToLongTimeString()}") .CacheOutput(builder => { builder.Expire(TimeSpan.FromSeconds(10)); });
Avere questa impostazione "inline" è sicuramente molto comodo, ma risulta impraticabile quando il numero degli endpoint aumenta, soprattutto se vogliamo mantenere una certa consistenza nel comportamento della nostra applicazione.
In questi casi, allora, è molto utile definire delle policy centralizzate, che poi possiamo utilizzare nei vari endpoint. Possiamo farlo in fase di registrazione del servizio:
builder.Services.AddOutputCache(config => { config.AddPolicy("shortCache", policy => { policy.Expire(TimeSpan.FromSeconds(30)); }); config.AddPolicy("longCache", policy => { policy.Expire(TimeSpan.FromMinutes(2)); }); });
Nello snippet in alto abbiamo definito due policy, shortCache e longCache, che possiamo poi referenziare tramite il loro nome, ove necessario:
app.MapGet("/cacheDemoShort", (string name) => $"Hello, {name}, time is {DateTime.Now.ToLongTimeString()}") .CacheOutput("shortCache"); app.MapGet("/cacheDemoLong", (string name) => $"Hello, {name}, time is {DateTime.Now.ToLongTimeString()}") .CacheOutput("longCache");
Tra tutte le policy, quella utilizzata per default è denominata Base Policy, e anch'essa può essere modificata in maniera simile:
builder.Services.AddOutputCache(config => { config.AddBasePolicy(policy => { policy.Expire(TimeSpan.FromSeconds(10)); }); // .. altre policy qui .. });
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Assegnare un valore di default a un parametro di una lambda in C#
Utilizzare i variable font nel CSS
Rendere i propri workflow e le GitHub Action utilizzate più sicure
Proteggere le risorse Azure con private link e private endpoints
Ordine e importanza per @layer in CSS
Managed deployment strategy in Azure DevOps
Ricevere notifiche sui test con Azure Load Testing
Creare una custom property in GitHub
Migliorare i tempi di risposta di GPT tramite lo streaming endpoint in ASP.NET Core
Usare il colore CSS per migliorare lo stile della pagina
Gestione dei nomi con le regole @layer in CSS
Fornire parametri ad un Web component HTML