No project description provided
Project description
amqtt_db
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:
- decoding the payload (e.G. from binary, JSON or which ever encoding)
- deserializing the payload to typed Python entities
- structure the session, topic, property, value information into a relational model of your choice
- 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
Built Distribution
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | dc3762fb5b5072a1d33401014d04b41dee4da7393f53a56b5786d067dbe5e8b9 |
|
MD5 | 908f0fe6e3032388e7339b091812e2e3 |
|
BLAKE2b-256 | 6f3199e5e1d7488f9c1b3586ba75d635125f85866ddb403da69cb2a24dc95a84 |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5e5dfb205c2cba82ea0be39aa3fb449c199003e909ba0f5f523f6379629d9dc8 |
|
MD5 | 93e572f0e1f26d3384d017558cf5945b |
|
BLAKE2b-256 | a65bf370ae0cd8267877dadb195e01c8ea0be0fc23e66ac960cac8e4978b0b8f |