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.
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.
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
Migliorare la sicurezza dei prompt con Azure AI Studio
Sfruttare MQTT in cloud e in edge con Azure Event Grid
Effettuare il log delle chiamate a function di GPT in ASP.NET Web API
Criptare la comunicazione con mTLS in Azure Container Apps
Definire stili a livello di libreria in Angular
Ordine e importanza per @layer in CSS
Migliorare l'organizzazione delle risorse con Azure Policy
Utilizzare un service principal per accedere a Azure Container Registry
Cambiare la chiave di partizionamento di Azure Cosmos DB
Creare un webhook in Azure DevOps
Gestire eccezioni nei plugin di Semantic Kernel in ASP.NET Core Web API