Azure IoT Hub è un servizio cloud gestito, pensato per mantenere connessi dispositivi e principalmente per ricevere e inviare messaggi. Di fatto viene sfruttato un Event Hub che è in grado di ricevere una grande quantità di messaggi che noi possiamo processare.
Nelle situazioni reali, è facile però dover gestire queste messaggi a seconda del tipo, della priorità o di altri fattori. Questa necessità nasce dal fatto che vogliamo eseguire attività diverse e con scalabilità diverse, scegliendo lo scenario più appropriato. Per esempio i messaggi di telemetria potrebbero essere processati da uno Stream Analytics, mentre messaggi di errore li vogliamo instradare ad una coda di Service Bus opportunamente monitorata da una Azure Function.
Per raggiungere questo scopo possiamo sfruttare il routing di Azure IoT Hub, cioè quella funzionalità che permette di instradare i messaggi a destinatari diversi. Quest'ultimi sono endpoint precedentemente configurati. Il primo passo quindi è quello di accedere al portale e nella sezione apposita, come nell'immagine.
Aggiungiamo un nuovo custom endpoint, indicando quale coda identificare, con namespace e nome.
Fatto questo possiamo accedere alla sezione routing e aggiungere una nuova regola. Dobbiamo prima di tutto scegliere su quale coda di messaggi lavorare, poiché in IoT Hub disponiamo due tipi di code. Successivamente indichiamo l'endpoint destinatario e quale regola applicare. Possiamo lavorare per esempio su un header del messaggio, come nell'esempio seguente.
Fatto questo possiamo salvare la regola ottenendo così l'instradamento desiderato. Il comportamento predefinito prevede che tutti i messaggi non individuati con regole, seguano il flusso tradizionale, ma una spunta ci permette di cambiare comportamento.
Per dettagli su quali condizioni possiamo scrivere, si veda il seguente indirizzo
https://docs.microsoft.com/it-it/azure/iot-hub/iot-hub-devguide-query-language#a-nameexpressions-and-conditionsaespressioni-e-condizioni
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Aggiungere interattività lato server in Blazor 8
Code scanning e advanced security con Azure DevOps
Autenticarsi in modo sicuro su Azure tramite GitHub Actions
Potenziare Azure AI Search con la ricerca vettoriale
Reactive form tipizzati con FormBuilder in Angular
Utilizzare Azure AI Studio per testare i modelli AI
Proteggere le risorse Azure con private link e private endpoints
Migliorare la sicurezza dei prompt con Azure AI Studio
Gestire domini wildcard in Azure Container Apps
Supporto ai tipi DateOnly e TimeOnly in Entity Framework Core
Creare una custom property in GitHub
Usare le navigation property in QuickGrid di Blazor
I più letti di oggi
- Sfruttare le API di geolocalizzazione di JavaScript
- Webcast 'Windows Vista: WinFX il framework per gli sviluppatori'
- Impostare il tema light o dark utilizzando i CSS
- Proteggere le risorse Azure con private link e private endpoints
- Cambiare automaticamente lo stato di un work item in una pipeline di Azure DevOps
- Criptare la comunicazione con mTLS in Azure Container Apps
- Ottimizzare l'aggiornamento di una entity sul database con Entity Framework
- Usare entità non mappate come parametri in metodi Invoke di WCF Ria Services e Silverlight
- Annunciata la licenza commerciale di Kinect for Windows: dal primo febbraio 2012