2019-11-17 16:27:58 +00:00
|
|
|
## Protos
|
|
|
|
|
|
|
|
The files from Protos are compiled by the gRPC compiler and provide data
|
|
|
|
structures that are shared across the project.
|
|
|
|
|
|
|
|
## Telemetry
|
|
|
|
|
2019-11-23 14:09:44 +00:00
|
|
|
It provides useful classes and abstractions for implementing telemetry
|
2019-11-17 16:27:58 +00:00
|
|
|
in individual components. All telemetry publishers use the MQTT protocol unless specified
|
|
|
|
otherwise.
|
|
|
|
|
|
|
|
### Azure Telemetry
|
|
|
|
|
|
|
|
#### Publisher
|
|
|
|
|
|
|
|
You can use cloud telemetry for free via Azure-IoT-Hub.
|
|
|
|
You still need a backend application that will process the messages.
|
|
|
|
|
|
|
|
You will need to create a:
|
|
|
|
- IoT Hub
|
|
|
|
- IoT Device
|
|
|
|
|
|
|
|
Then navigate to your device and grab the primary key, you will need it to create
|
|
|
|
a connection string of the form:
|
|
|
|
|
|
|
|
`HostName=YOUR_IOT_HUB_NAME.azure-devices.net;DeviceId=YOUR_DEVICE_NAME;SharedAccessKey=PRIMARY_OR_SECONDARY_KEY`
|
|
|
|
|
|
|
|
The connection string can be passed to the application via `appsettings.json` or command line arguments or environment variables:
|
|
|
|
```
|
2019-11-24 12:32:16 +00:00
|
|
|
dotnet run --Telemetry:ConnectionString=CONNECTION_STRING
|
|
|
|
export Telemetry:ConnectionString=CONNECTION_STRING
|
2019-11-17 16:27:58 +00:00
|
|
|
```
|
2019-11-23 14:09:44 +00:00
|
|
|
|
|
|
|
### Reader
|
|
|
|
|
|
|
|
A telemetry reader can be found in NucuCar.TestClient. You'll need a connection string that can be found in
|
|
|
|
Azure's IoT Hub Build-In Endpoints setting.
|
2020-01-24 14:12:58 +00:00
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
### Disk Telemetry
|
|
|
|
|
|
|
|
#### Publisher
|
|
|
|
|
|
|
|
Publishes telemetry on the disk.
|
|
|
|
|
|
|
|
Example connection string:
|
|
|
|
`Filename=telemetry;FileExtension=csv;Separator=,;BufferSize=4096`
|
|
|
|
|
|
|
|
See the source code for comments on the ConnectionString.
|
|
|
|
|
|
|
|
### Reader
|
|
|
|
|
|
|
|
You will need to parse the file by yourself.
|