Skip to main content

No project description provided

Project description

amqtt_db

license Build Status Coverage Status PyPI Documantation

DB persistence for amqtt.

Objective

amqtt_db persists payloads received by the amqtt broker into performant relational databases. SQLAlchemy as well as timescaleBD are the target RMDB-Systems.

amqtt_db will do four steps to persist the amqtt data:

  1. decoding the payload (e.G. from binary, JSON or which ever encoding)
  2. deserializing the payload to typed Python entities
  3. structure the session, topic, property, value information into a relational model of your choice
  4. generate the necessary tables, columns to store the data

All of this steps can be configured via the amqtt yaml config. And you can even replace any these steps for each topic by your code in terms of Python plugins. amqtt is designed to be enhanced and extended.

Performance

Flexibility comes with a penalty on performance. The more layers of classes and filters we implement the higher the performance penalty.

So we optimize the data flow by an optimistic approach.

amqtt_db expects that the decoding, deserializing, transformations, target DB, target tables, table colums etc. are all well in place if it deals with a single incoming packet. If the handling of that package fails, exceptions will be raised, and the error handling rushes in to deal with the problem.

Since the change rate on the decoding, deserializing, database model is quite low this optimistic approach will be quite performant.

Documentation

Please have a look at the documentation.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

amqtt_db-0.1.5.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

amqtt_db-0.1.5-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file amqtt_db-0.1.5.tar.gz.

File metadata

  • Download URL: amqtt_db-0.1.5.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.11.2 Linux/6.1.0-17-amd64

File hashes

Hashes for amqtt_db-0.1.5.tar.gz
Algorithm Hash digest
SHA256 dc3762fb5b5072a1d33401014d04b41dee4da7393f53a56b5786d067dbe5e8b9
MD5 908f0fe6e3032388e7339b091812e2e3
BLAKE2b-256 6f3199e5e1d7488f9c1b3586ba75d635125f85866ddb403da69cb2a24dc95a84

See more details on using hashes here.

File details

Details for the file amqtt_db-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: amqtt_db-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 20.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.1 CPython/3.11.2 Linux/6.1.0-17-amd64

File hashes

Hashes for amqtt_db-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 5e5dfb205c2cba82ea0be39aa3fb449c199003e909ba0f5f523f6379629d9dc8
MD5 93e572f0e1f26d3384d017558cf5945b
BLAKE2b-256 a65bf370ae0cd8267877dadb195e01c8ea0be0fc23e66ac960cac8e4978b0b8f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page