Il servizio API Management di Azure permette di esporre e di centralizzare sotto un unico cappello servizi ospitati sulla piattaforma e fornendo un layer comune che si occupi di inserire regole di autenticazione, autorizzazione o di throttling. Permette inoltre di ottenere una documentazione e un portale per la gestione degli applicativi e degli utenti che utilizzano le nostre API.
Si tratta quindi di un reverse proxy avanzato e scalabile che gira le richieste HTTP a servizi di backend. Non si limita però, solo a chiamate HTTP/HTTPS ma esso è in grado anche di esporre WebSocket, cioè i canali bidirezionali che permettono la creazione di comunicazioni realtime, godendo allo stesso tempo delle policy che abbiamo definito.
Per sfruttare questa funzionalità è sufficiente selezionare l'API di tipo WebSocket quando definiamo una nuova API. Ci vengono chiesti i soliti dati, come il nome, la descrizione e i metadati relativi al prodotto o i tag, ma oltre a questi anche l'indirizzo del canale WebSocket di backend.
![](https://www.cloudnativeitalia.com/script/images/241.jpg)
Sono supportati canali in chiaro (WS) o criptati (WSS) e l'eventuale suffisso da apporre al dominio base. Creata l'API ci ritroviamo con un'unica operazione GET di nome onHandshake che rappresenta la prima fase nella quale il canale viene stabilito. In questa fase possiamo mettere le policy, ma non possiamo intervenire sui messaggi che vengono scambiati. Nell'apposita sezione Test possiamo poi provare l'API stessa, procedendo prima all'avvio della connessione e poi all'invio di eventuali messaggi.
![](https://www.cloudnativeitalia.com/script/images/241_2.jpg)
Sebbene questa funzionalità sia molto utile bisogna sottolineare che sono presenti dei limiti, tra i quali l'impossibilità di usare questa funzionalità nel tier a consumo e il numero massimo di 200 connessioni per unità. Vi sono poi delle policy che non possiamo utilizzare, alcune delle quali per ovvi motivi, come la risposta di mock, l'utilizzo della cache o l'intervento nella richiesta o nella risposta.
Per maggiori informazioni rimandiamo all'indirizzo https://learn.microsoft.com/en-us/azure/api-management/websocket-api
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Eseguire attività pianificate con Azure Container Jobs
Eseguire un metodo asincrono dopo il set di una proprietà in Blazor 8
Garantire la provenienza e l'integrità degli artefatti prodotti su GitHub
Filtering sulle colonne in una QuickGrid di Blazor
Gestire liste di tipi semplici con Entity Framework Core
Creare un'applicazione React e configurare Tailwind CSS
Eseguire attività con Azure Container Jobs
Hosting di componenti WebAssembly in un'applicazione Blazor static
Short-circuiting della Pipeline in ASP.NET Core
Utilizzare Azure AI Studio per testare i modelli AI
Generare token per autenicarsi sulle API di GitHub