Nel precedente script #1033 abbiamo visto come è possibile utilizzare i Task del .NET Framework 4.0 in una pagina ASP.NET Web Forms. A partire dalla versione 2, anche ASP.NET MVC supporta l'esecuzione di operazioni asincrone all'interno dei controller, grazie alla nuova classe base AsyncController.
Supponiamo, ad esempio, di avere la necessità di invocare un servizio esterno, che potrebbe impiegare alcuni secondi a rispondere, durante i quali il nostro web server resterebbe inutilmente bloccato. In una simile situazione, sfruttare i controller asincroni ci consente di liberare un thread sul server web così che, in attesa della conclusione della chiamata, questo possa essere sfruttato per servire una richiesta di un altro utente, migliorando pertanto la scalabilità dell'applicazione.
Un controller in grado di supportare un simile comportamento deve ereditare dalla già citata classe AsyncController ed implementare una coppia di metodi per ogni Action asincrona. Nel nostro caso, l'invocazione di un servizio di previsioni del tempo potrà essere realizzata tramite la action ShowWeather seguente:
public void ShowWeatherAsync(string zipCode) { var weatherService = new WeatherForecastSoapClient("WeatherForecastSoap"); // segnaliamo la presenza di una nuova operazione asincrona in esecuzione this.AsyncManager.OutstandingOperations.Increment(); // impostiamo il metodo di callback da eseguire al termine dell'invocazione weatherService.GetWeatherByZipCodeCompleted += (s, e) => { this.AsyncManager.Parameters["result"] = e.Result; this.AsyncManager.OutstandingOperations.Decrement(); }; weatherService.GetWeatherByZipCodeAsync(zipCode); } public ViewResult ShowWeatherCompleted(WeatherForecasts result) { return this.View(result); }
I due metodi, il cui nome è costituito dal nome della action seguito dai suffissi -Async e -Completed, hanno rispettivamente il compito di iniziare l'esecuzione asincrona e di restituire una view come ActionResult. In particolare, ShowWeatherAsync segnala innanzi tutto all'AsyncManager la presenza di una nuova operazione asincrona in corso, incrementando il contatore delle OutstandingOperations.
Successivamente imposta un metodo di callback da eseguire al termine dell'invocazione, che oltre a decrementare il contatore di conseguenza, valorizza una voce del dictionary Parameters, così che il risultato del web service possa essere fornito come parametro al metodo -Completed. ShowWeatherCompleted, infatti, presenta tale argomento nella signature del metodo, utilizzandolo direttamente come Model per la View che restituisce come risultato.
Come detto in precedenza, tale approccio è vantaggioso perché, nel caso di chiamate a Web Service, libera un thread sul server e lo rende disponibile per servire ulteriori richieste, migliorando pertanto le prestazioni dell'applicazione nel suo insieme, sebbene il tempo della singola risposta rimanga invariato. In un prossimo script vedremo invece come questo approccio possa essere sfruttato per eseguire operazioni in parallelo, rendendo più veloce anche il rendering della singola pagina.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Disabilitare automaticamente un workflow di GitHub
Change tracking e composition in Entity Framework
Code scanning e advanced security con Azure DevOps
Evitare il flickering dei componenti nel prerender di Blazor 8
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Triggerare una pipeline su un altro repository di Azure DevOps
Creare una libreria CSS universale: i bottoni
Creazione di componenti personalizzati in React.js con Tailwind CSS
Creare un webhook in Azure DevOps
Gestione dei nomi con le regole @layer in CSS
Combinare Container Queries e Media Queries
Generare la software bill of material (SBOM) in GitHub