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
Creare una libreria CSS universale: i bottoni
Eseguire query per recuperare il padre di un record che sfrutta il tipo HierarchyID in Entity Framework
Fornire parametri ad un Web component HTML
Documentare i servizi REST con Swagger e OpenAPI con .NET 9
Sfruttare GPT-4o realtime su Azure Open AI per conversazioni vocali
Utilizzare l'espressione if inline in una pipeline di Azure DevOps
Ottenere un token di accesso per una GitHub App
Utilizzare DeepSeek R1 con Azure AI
Gestire i dati con Azure Cosmos DB Data Explorer
Il nuovo controllo Range di Blazor 9
Generare velocemente pagine CRUD in Blazor con QuickGrid
Rendere le variabili read-only in una pipeline di Azure DevOps