Optimizing Sensor Data Transmission: Storing Locally and Sending to IoT Hub

Hi guys I'm working on a Raspberry Pi project where I need to send sensor data to IoT Hub. Due to latency, I lose around 5 samples per second. I'm thinking of storing the data locally in a CSV file every 10 seconds with one process and then reading and sending it to the cloud with another process. How possible is this? @IoT Cloud
6 Replies
LMtx
LMtx8mo ago
Manage data streams on Greengrass core devices - AWS IoT Greengrass
Use AWS IoT Greengrass V2 stream manager to process data streams and export or upload stream data to the AWS Cloud.
Joseph Ogbonna
Joseph Ogbonna8mo ago
Yes, it's possible to store sensor data locally in a CSV file every 10 seconds with one process and then read and send it to the cloud with another process. This approach can help reduce latency. It can also ensure reliable file transmission. But ensure you have proper error handling mechanism in check.
Nehal
Nehal8mo ago
Can you tell us more about what type of data is this? how are you sending data, frequency of sending data? what size and how long is this packet and how are you receiving, parsing and packaging the data? Getting more info will definitely be better to comment on your problem.
Daniel kalu
Daniel kalu8mo ago
The data are sensor readings for temperature and humidity. I'm planning to send the data to the IoT Hub using MQTT protocol. The frequency of sending data is around 10 samples per second, but due to latency issues, I lose about 5 samples per second. Each sample is small, about 100 bytes. I receive the data on the Raspberry Pi, parsing it, and then packaging it into CSV format for storage
Nehal
Nehal8mo ago
Instead of collecting and sending data 10 times per second, create an array store the values and send this array as 1 packet per second You can also collect more and send that data like array size of 20 for 2 sec interval cycle. Along side you should also store data incase of connection or data lost scenarios. Also packet of 100 bytes is kind of big you should try to reduce it if there's repetitive data residing inside it like MAC address etc it will make your flow lighter to execute
Daniel kalu
Daniel kalu8mo ago
Thanks for the advice! I'll implement storing data in an array and sending it as one packet per second.
Want results from more Discord servers?
Add your server