Skip to content

Latest commit

 

History

History
132 lines (96 loc) · 4.69 KB

README.md

File metadata and controls

132 lines (96 loc) · 4.69 KB

IoT Monitor Central Repository

This is a monorepo with the following services:

and the gRPC/Protobuf definition, OpenTelemetry, MQ, database modules.

Run

This project is highly optimized for Zeabur, which is the recommended PaaS for this IoT Monitor project.

You should prepare your PostgreSQL, RabbitMQ and EntityRecognition instance. Besides, you may need to configure Grafana Alloy, so you can monitor the telemetry of services.

Place the following config.toml in the working directory or /etc/iotmonitor/config.toml, ~/.config/iotmonitor/config.toml:

# DATABASE
[postgres]
host = "${POSTGRES_HOST}"
port = "5432"  # or leave blank for default
user = "${POSTGRES_USER}"
password = "${POSTGRES_PASSWORD}"
dbname = "${POSTGRES_DB}"
sslmode = "disable"  # https://www.postgresql.org/docs/current/libpq-ssl.html

# TELEMETRY
[telemetry.endpoint.otlp]
endpoint = "localhost:4318"
insecure = true

# SERVICES – Entity Recognition
[service.entityrecognition]
uri = "entity-recognition.your-gpu-machine.internal"
tls = { cert_file = "/etc/iotmonitor/services/entityrecognition/cert.pem", key_file = "/etc/iotmonitor/services/entityrecognition/key.pem" }

# SERVICES - Public Event Facade
[service.publiceventfacade]
port = 1145  # by default, it is 8080
[service.publiceventfacade.tls]
cert_file = "/etc/iotmonitor/services/publiceventfacade/cert.pem"
key_file = "/etc/iotmonitor/services/publiceventfacade/key.pem"

# NOTIFICATION PUBLISHER
[service.notificationpublisher]
public_event_facade_uri = "event-aggregator.your-machine.internal:8080"
update_period = "1m"  # how long should we poll the database for new events

# RABBITMQ
[mq]
uri = "${RABBITMQ_URI}"

# MQTT
[mq.mqtt]
uri = "tcp://mqtt-broker.iot.local:1883"

To build the service, you should install Taskfile runner, then you can run the command to build the microservices:

task service-event-aggregator  # task service-[service name], single service
task service-all               # all services

Then you can run the service:

./out/event-aggregator

Development

You should build the protobuf and schema first. We provide a simple command to generate these:

task generate

I use GoLand for development, but you can use any editor you like.

Production deployment

wip (Zeabur template)

Specification

Must mean the field is required. Can mean the field is optional.

AMQP Message Specification

For a Event:

  • The Exchange must be events_topic, and the Message Key must be in event.v1.[event_type].
  • The Message ID must be the event ID, and must be in UUID v7 format (ordered by time).
  • The Timestamp must be the emitted timestamp of the event.
  • The App ID must be your device ID.
  • The Content Type must be application/x-google-protobuf, and the Type should be eventpb.EventMessage.
  • The body must be formed in eventpb.EventMessage and encoded in Protobuf Binary format.
  • The header can contain the W3C Trace Context and W3C Baggage information.
    • The header key of Trace Context should be tracestate and traceparent.
    • The header key of Baggage should be baggage.
  • The header can contain the parent_event_id. If there is one, it must be in UUID format.

The implementation can be seen in publish_event.go.

MQTT Message Specification

For a Event:

  • The Topic must be iot/events/v1/[event_type].
  • The Content Type must be application/x-google-protobuf.
  • The Payload must be formed in eventpb.EventMessage and encoded in Protobuf Binary format.
  • The Header must contain event_id, and it must be in UUID v7 format (ordered by time).
  • The Header must contain non-empty device_id.
  • The Header must contain emitted_at of the event, and must be in the RFC3339Nano format.
  • The Header can contain the parent_event_id optionally. If there is one, it must be in UUID format.
  • The Header can contain the W3C Trace Context and W3C Baggage information.
    • The header key of Trace Context should be tracestate and traceparent.
    • The header key of Baggage should be baggage.

License & Author

This project is licensed under the AGPL-3.0-or-later license. See the LICENSE file for details.

This project is authored by Yi-Jyun Pan (pan93412).