Storage and database adapters available in project Thoth
Project description
This library provides a library called thoth-storages used in project Thoth. The library exposes core queries and methods for Dgraph database as well as adapters for manipulating with Ceph via its S3 compatible API.
Installation and Usage
The library can be installed via pip or Pipenv from PyPI:
pipenv install thoth-storages
The library does not provide any CLI, it is rather a low level library supporting other parts of Thoth.
You can run prepared testsuite via the following command:
pipenv install --dev
pipenv run python3 setup.py test
# To generate docs:
pipenv run python3 setup.py build_sphinx
Automatically generate schema for Graph database
To automatically generate schema for the graph database from models defined in this module, run:
PYTHONPATH=. pipenv run python3 ./create_schema.py --output thoth/storages/graph/schema.rdf
After running this command, the RDF file describing schema will be updated based on changes in model.
from thoth.storages import GraphDatabase
# Also provide configuration if needed.
graph = GraphDatabase()
graph.connect()
graph.initialize_schema()
Running Dgraph locally
You can use docker-compose present in this repository to run a local Dgraph instance. It does not use TLS certificates (so you must not to provide GRAPH_TLS_PATH environment variable).
$ docker-compose up
After running the command above (make sure your big fat daemon is up using systemctl start docker), you should be able to access a local Dgraph instance at localhost:9080. This is also the default configuration for Dgraph’s adapter - you don’t need to provide GRAPH_SERVICE_HOST explicitly.
The provided docker-compose has also Ratel enabled for to have an UI for graph database content. To access it visit http://localhost:8000/.
The provided docker-compose uses volume mounted from /tmp. After you computer restart, the content will not be available anymore.
If you would like to experiment with Dgraph programatically, you can use the following code snippet as a starting point:
from thoth.storages import GraphDatabase
graph = GraphDatabase()
graph.connect()
# To clear database:
# graph.drop_all()
# To initialize schema in the graph database:
# graph.initialize_schema()
Schema adjustment in deployment
It’s possible to perform adjustments of schema in a deployemnt. It’s important that there are no open transactions (simply retry schema creation until it succeeds). You can use relevant endpoint on Management API for this purpose.
If there are changes in types, Dgraph tries to automatically perform conversion from an old type to the new one as described in the new schema (e.g. a float to string). Invalid schema changes (e.g. parsing string into a float, but the string cannot be parsed as a float) result in schema change errors. These errors need to be handled programatically by deployment administrator (ideally avoid such conversions).
Creating own performance indicators
You can create your own performance indicators. To create own performance indicator, create a script which tests desired functionality of a library. An example can be matrix multiplication script present in performance repository. This script can be supplied to Dependency Monkey to validate certain combination of libraries in desired runtime and buildtime environment or directly on Amun API which will run the given script using desired software and hardware configuration. Please follow instructions on how to create a performance script shown in the README of performance repo.
To create relevant models, adjust thoth/storages/graph/performance.py file and add your model. Describe parameters (reported in @parameters section of performance indicator result) and result (reported in @result). The name of class should match name which is reported by performance indicator run.
@attr.s(slots=True)
class PiMatmul(PerformanceIndicatorBase):
"""A class for representing a matrix multiplication micro-performance test."""
SCHEMA_PARAMETERS = Schema({
Required("matrix_size"): int,
Required("dtype"): str,
Required("reps"): int,
Required("device"): str,
})
SCHEMA_RESULT = Schema({
Required("elapsed"): float,
Required("rate"): float,
})
# Device used during performance indicator run - CPU/GPU/TPU/...
device = model_property(type=str, index="exact")
matrix_size = model_property(type=int, index="int")
dtype = model_property(type=str, index="exact")
reps = model_property(type=int, index="int")
elapsed = model_property(type=float)
rate = model_property(type=float)
After you have created relevant model, register your model to ALL_PERFORMANCE_MODELS and re-generate graph database schema (as discussed above).
Online debugging of queries done to Dgraph
You can print to logger all the queries that are performed to a Dgraph instance. To do so, set the following environment variables:
export THOTH_LOG_STORAGES=DEBUG
export THOTH_STORAGES_DEBUG_QUERIES=1
Project details
Release history Release notifications | RSS feed
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 thoth-storages-0.15.2.tar.gz
.
File metadata
- Download URL: thoth-storages-0.15.2.tar.gz
- Upload date:
- Size: 39.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/36.5.0 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.6.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ad9f69da236f99c49ff23ad197e26cd84bf97e85de649a9951503f70fed3fa54 |
|
MD5 | 7a089d06c18d7b381f691635e8458c94 |
|
BLAKE2b-256 | 1e081a24dc99bde910e2e646667718e8266f90b656f1b46525c25cb7e9d82adc |
File details
Details for the file thoth_storages-0.15.2-py3-none-any.whl
.
File metadata
- Download URL: thoth_storages-0.15.2-py3-none-any.whl
- Upload date:
- Size: 62.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/36.5.0 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/3.6.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b627d2916d02e6229ca8113f2ad79a03ed7ade50b658021bd427d647e29f4b02 |
|
MD5 | 239e47bdc65c898f4fd7bb5750f4a8c9 |
|
BLAKE2b-256 | c35339c0b77254af263f01d3f0613da025b75b8e1804c891b308f40ef91c7059 |