Le Azure Function sono state introdotte nella piattaforma cloud per permette la definizione di funzioni da eseguire ignorando completamente l'ambiente in cui vengono eseguite. L'unica logica di riferimento è la funzione, la quale può essere attivata tramite trigger. Per renderne immediato l'utilizzo, fin dall'inizio la definizione di funzioni era affidata a metodi statici, proprio per evidenziare l'atomicità del metodo stesso.
Dalla versione 2.0.12265 del runtime delle Azure Functions, è stato inserito l'utilizzo di ASP.NET Core 2.2 come runtime, ma anche il supporto all'invocazione di metodi di istanza e non solo statici. Questo vuol dire che ci è sufficiente togliere la parola chiave static e ottenere la creazione di una nuova istanza della classe tutte le volte che la funzione invocata. Questo risulta utile quando abbiamo bisogno di memorizzare dati a livello di classe per tutta la durata dell'esecuzione.
Per esempio, possiamo usare il motore di dependency injection per risolvere una dipendenza da usare all'interno della singola richiesta.
public class MyFunction
{
private static readonly ServiceProvider Provider;
static MyFunction()
{
// Definizione dei servizi
IServiceCollection services = new ServiceCollection();
services.AddTransient<TestService>();
// Creazione provider
Provider = services.BuildServiceProvider();
}
private readonly TestService _service;
public MyFunction()
{
// Risoluzione della dipendenza per questa istanza
_test = Provider.GetRequiredService<TestService>();
}
[FunctionName("MyFunction")]
public async Task<IActionResult> Run(
[HttpTrigger(AuthorizationLevel.Function, "get")] HttpRequest req,
ILogger log)
{
// Utilizzo della dipendenza
string message = await _test.GetMessageAsync();
return new OkObjectResult(message);
}
}
}Nello snippet precedente possiamo notare l'utilizzo di una normale classe. Nel costruttore statico definiamo una sola volta le dipendenze ed istanziamo il provider. Successivamente risolviamo la dipendenza nel costruttore di istanza della classe, per poi utilizzarla dove ci serve.
Il passaggio all'uso di istanza si dimostra utile, quindi, soprattutto quando necessitiamo di campi privati che vengono persi terminata la richiesta.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Eseguire query in contemporanea con EF
Evitare memory leaks nelle closure JavaScript
Centralizzare gli endpoint AI Foundry con Azure API Management
Utilizzare Intersect e Except per filtrare set di dati in TSql
Disabilitare le run concorrenti di una pipeline di Azure DevOps
Abilitare il rolling update su Azure Functions flex consumption
Creare agenti facilmente con Azure AI Agent Service
.NET Aspire per applicazioni distribuite
Loggare le query più lente con Entity Framework
Creare un agente A2Acon Azure Logic Apps
Gestione file Javascript in Blazor con .NET 9
Definire il metodo di rilascio in .NET Aspire
I più letti di oggi
- Effettuare il multi-checkout in linea nelle pipeline di Azure DevOps
- Sfruttare una CDN con i bundle di ASP.NET
- Esaminare documenti XML con namespace utilizzando LINQ to XML
- Alleggerire le applicazioni WPF sfruttando gli oggetti Freezable
- Inserire le news di Punto Informatico nel proprio sito
- Effetto turnstile su tutte le pagine con il Windows Phone Toolkit
- Le DirectInk API nella Universal Windows Platform
- Gli oggetti CallOut di Expression Blend 4.0


