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
Disabilitare automaticamente un workflow di GitHub
Limitare le richieste lato server con l'interactive routing di Blazor 8
Accesso sicuro ai secrets attraverso i file in Azure Container Apps
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Sviluppare un'interfaccia utente in React con Tailwind CSS e Preline UI
Inizializzare i container in Azure Container Apps
Gestire i null nelle reactive form tipizzate di Angular
Eseguire attività con Azure Container Jobs
Utilizzare la session affinity con Azure Container Apps
Migrate and Modernize your .NET Applications on Azure
Gestire undefined e partial nelle reactive forms di Angular
Utilizzare Model as a Service su Microsoft Azure
I più letti di oggi
- I tutorials, percorsi guidati per tutti
- Costruire applicazioni cross-plaftorm con Visual Studio 2013 e Xamarin
- Creare semplici grafici a barre con ASP
- rilasciato #mono 2.8.1: bug fix importanti, anche di security: http://u.aspitalia.com/o5
- Mappare una relazione uno a molti con Entity Framework Code First
- Dichiarare tutte le proprietà di un record usando solo il costruttore in C#
- Gestire la cancellazione di una richiesta in streaming da Blazor
- Fragment Caching con dipendenza da altri controls
- grazie a tutti per aver seguito #aspilive! tutto il materiale è già online e le registrazioni saranno pubblicate nei prossimi giorni su => https://aspit.co/BlazorConf-20
- Modificare i metadati nell'head dell'HTML di una Blazor Web App