Skip to content

Store all incoming 🦟MQTT messages on 🍃MongoDB

Notifications You must be signed in to change notification settings

juniorsaldanha/MQTT2MongoDB

 
 

Repository files navigation

CI Open Source Love svg1 MIT license made-with-python

MQTT2MongoDB

A simple Python project that listen to one or more MQTT topics and save all the incoming messages on a MongoDB database, as some sort of logger.

Sections

  1. MQTT2MongoDB
  2. Deploy
    1. Deploy only MQTT2MongoDB
    2. Deploy MQTT2MongoDB MQTT MongoDB
    3. Debug with docker-compose
    4. Build and run as Daemon without mapping the appsettings file
  3. Requirements
  4. Settings
  5. Features
  6. Document Format in MongoDB

Requirements

  • Python 3.x (tested on python:3.8-slim-buster in container)
  • Tested on Docker with docker-compose on Mac OS Big Sur
  • A working, available MQTT broker
  • A working, available MongoDB server
  • Libraries:
  • Docker + docker-compose is recommended if available

Settings

Settings for MQTT Broker and MongoDB server can be placed on the appsettings.json file.


Features

  • Separated Threads for MQTT and MongoDB
  • MQTT with callback and subscribers list of topics
  • MongoDB with new thread for each save in MongoDB
  • Queue implemented to communicate data between MQTT and MongoDB
  • Decode JSON from MQTT message and save as Object in MongoDB
  • Save timestamp and datetime (ISO 8601) in Document which will be recognized as Date in MongoBD

Document Format in MongoDB

When payload is a text will be something like

{
    "_id": {
        "$oid": "6115d9581049eacf18f6cd9e"
    },
    "topic": "topic1/subtopic/teste",
    "payload": "Just some text, :)",
    "qos": 0,
    "timestamp": 1628821848,
    "datetime": "2021-08-13T02:30:48.807958"
}

Or when your payload is a json, the document in mongodb will be like below

{
    "_id": {
        "$oid": "6115d9181049eacf18f6cd9d"
    },
    "topic": "topic1/subtopic/teste",
    "payload": {
        "key1": "value1",
        "key2": 2.5,
        "somelist": [
            "item1",
            "item2",
            "item3"
        ]
    },
    "qos": 0,
    "timestamp": 1628821784,
    "datetime": "2021-08-13T02:29:44.901154"
}

Deploy

Deploy only MQTT2MongoDB

curl -sS https://raw.githubusercontent.com/juniorsaldanha/MQTT2MongoDB/master/deploy.sh | bash -s only-mqtt2mongodb

Deploy MQTT2MongoDB MQTT MongoDB

curl -sS https://raw.githubusercontent.com/juniorsaldanha/MQTT2MongoDB/master/deploy.sh | bash -s full

Debug with docker-compose

To Debug with docker container and vscode use the command below, or if you have Docker extension on vscode just right-click on docker-compose.debug.yml

docker-compose -f "docker-compose.debug.yml" up --build -d

and use "Python: Remote Attach" on Debug option.


Build and run as Daemon without mapping the appsettings file

To run as service on background use the command below

docker-compose -f "docker-compose.yml" up --build -d

About

Store all incoming 🦟MQTT messages on 🍃MongoDB

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 57.2%
  • Shell 34.8%
  • Dockerfile 8.0%