Skip to content

Il repo contiene il prototipo di un'architettura scalabile utilizzabile in un contesto IoT.

Notifications You must be signed in to change notification settings

raphael2692/iot-demo

Repository files navigation

IoT Architecture Demo

Architettura

Il repo contiene il prototipo di un'architettura scalabile utilizzabile in un contesto IoT.

I componenti principali dell'applicazione sono:

  1. Un broker mqtt (mosquitto)
  2. Un servizio producer (crea un dato finto e lo invia al topic /temperatura)
  3. Un servizio consumer (quando viene pubblicato un nuovo messaggio su /temperatura invia il dato a un db remoto)
  4. MongoDB Atlas un istanza online di MongoDB
  5. FastAPI un framework REST per esporre i dati in database a dei client front-end. 100% compliant allo standard OpenAPI (Swagger)
  6. Una dashboard responsiva in React.

Ogni componente è dockerizzato (tranne il database). Per far girare l'applicazione la prima volta digitare:

sudo docker-compose up --build

Dopodiché si può omettere --build (a meno che non si istallino nuove dipendenze).

Una volta che il servizio è attivo, è possibile modificare il sorgente senza bisogno di riavviare per buildare le modifiche.

Possibili pull request:

  1. Implementare l'autenticazione dei metodi su FastAPI
  2. Implementare uno scambio di certificati di sicurezza su mqtt
  3. Sostituire Atlas con un container dedicato e implementare un metodo di autenticazione robusto (flusso consumer -> mongo)
  4. Creare un clone dell'app che supporti Postgres invece di mongo (va cambiato l'ORM lato FastAPI, ad es. sqlalchemy invece di Motor)
  5. Creare un clone della dashboard con Vue.JS
  6. Connettere dei nuovi sensori "fake" e creare nuove route (sul backend) e view (sul frontend)
  7. Creare un modello di forecasting della temperatura e implementare su FastAPI una route per le predizioni e delle view interessanti su React
  8. Implementare un meccanismo di job watching e load balancing
  9. Trovare un modo per aggiornare il componente React del grafico solo se i dati sono diversi (e non ogni volta che viene fatta una richiesta http)
  10. Implementare CI/CD su gitlab (risolvere prima il networking interno e la build del frontend)
  11. Implementare un webserver production-ready (nginx)
  12. Scrivere i test

Screenshot

Dashboard

Dashboard


Swagger

FastAPI

TODO

  1. Migliorare il networking dell'applicazione
  2. Risolvere npm start fail su installazioni di docker diverse (probabilmente va rivisto il Dockerfile della dashboard)

About

Il repo contiene il prototipo di un'architettura scalabile utilizzabile in un contesto IoT.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published