Skip to content

Latest commit

 

History

History
76 lines (54 loc) · 3.5 KB

README.md

File metadata and controls

76 lines (54 loc) · 3.5 KB

mqtt-to-eventhub

A basic python script to fetch messages from an MQTT broker and push them to an Azure Event Hub. Uses Asyncio MQTT and the async pattern from the Azure Event Hub Client Library to batch messages to make it more efficient - it can easily handle a thousand or more messages per minute on my raspberry pi model 4 8gb. Because of the use of asyncio, it has a minimum python version of 3.9.

Losely tested with Python versions 3.9, 3.10, 3.11.

how to run the script

  1. install build dependencies
    • see Cryptography for most build requirements - some others also needed sudo apt-get install-y cmake build-essential libssl-dev libffi-dev \ python3-dev cargo pkg-config gcc musl-dev git-all
  2. Go to your home folder: cd ~
  3. clone the folder: git clone https://github.com/mnbf9rca/mqtt-to-eventhub.git
  4. change to the follder: cd mqtt-to-enventhub
  5. copy .env.example to .env populate it with your values
  6. create a venv: python3.9 -m venv .venv
  7. activate: source ./.venv/bin/activate
  8. Install Poetry using a script from the Poetry website: curl -sSL https://install.python-poetry.org | python3 -

This app uses Poetry as the package manager. However Poetry doesnt support alternative sources very well. That means that it ignores https://www.piwheels.org/ and tries to build uamqp from scratch - which means building scipy from scratch, which takes literally hours. Instead, we can choose to export the package dependencies to a requirements.txt file, It'll still take a while (for some reason it still builds Cryptography) but not nearly as long.

option 1 - use requirements.txt

  1. export the requirements: poetry export --format requirements.txt --output requirements.txt
  2. install setuptools and wheel: pip install wheel setuptools
  3. use pip to install: pip install -r requirements.txt

option 2 - use poetry (e.g. on a VM or something more powerful)

  1. Install requirements: poetry install --without test,dev --no-root --verbose

finally...

  1. Run: python mqtt-to-eventhub.py

how to install mqtt-to-eventhub as a script

FINALLY ONCE THE SCRIPT RUNS OK: Create the mqtttoeventhub.service and enable it so the script runs on boot up as follows: Do: CTRL-C to stop the script then - Do: sudo nano /etc/systemd/system/mqtttoeventhub.service and copy & paste in the following (using the chosen script name) ...

The script below assumes the user is pi. If not, replace pi with the username you're using.

[Unit]
Description=MQTT to EventHub
After=network.target
After=mosquitto.service
StartLimitIntervalSec=0

[Service]
Environment=DOTENV_KEY=""
WorkingDirectory=/home/pi/mqtt-to-eventhub/
Type=simple
Restart=always
RestartSec=1
User=pi
ExecStart=/home/pi/mqtt-to-eventhub/.venv/bin/python /home/pi/mqtt-to-eventhub/mqtt-to-eventhub.py

[Install]
WantedBy=multi-user.target

Then save & exit and to ensure the mqtttoeventhub.service runs on boot up - Do: sudo systemctl enable mqtttoeventhub.service

AS A VERY LAST CHECK - Do: sudo reboot then SSH in again and check the service is active with: systemctl status mqtttoeventhub.service

Finally close the SSH terminal. The script/service will continue to run surviving any future reboots