Bariot is a simple solution to send, manage, secure and visualize data from connected devices/machines.
Drawing by Ngoc-Ha
Micro-services architecture build with Go and Docker (compose).
Inspired by the beautiful architecture of Mainflux.
Bariot is being developed to offer a simple, complete and scalable solution to wide variety of IoT projects.
Bariot uses the most recent (ref 2022) technologies to create a scalable and cloud agnostic IoT/IIoT platform.
Bariot is opinionated, in the sense that storage and communications technologies are predefined (see COMPONENTS)
Bariot is a chance to understand what technologies are used to create cloud applications with modern standards of security, scalability, performances and devops practices. Whether it is purely serverless or containerized, these components (see below) in one form or another are often involved.
Bariot is also a fun project to work on !
Deployment on AWS EC2 here. (with docker-compose)
- Transport: MQTT
- Authentication/Authorization: JWT
- USER, THINGS storage: PostgreSQL
- THINGS DATA storage: Influxdb
- Services intercommunication: gRpc
- Services messaging: Nats
- Data presentation: Grafana
- Data streaming: Websockets
- Reverse proxy: Nginx
- Caching: Redis
- Testing Unit, Integration, End to End: GoTest