Skip to main content

A faster replacement for google-cloud-datastore

Project description

A hexagonal logo of the viur-datastore

viur-datastore

Badge showing current PyPI version Badge displaying the license
The Datastore wrapper for ViUR-Core

About

This repository contains the datastore wrapper for the ViUR framework. We build our own wrapper around it's REST-API as the original wrapper has significant CPU overhead. Using a fast JSON-Parser (simdjson) and Cython, we can go directly from the received JSON-encoded protocol-wrapper representation to the final python objects, without converting that JSON into an intermediate python object representation which then gets discarded right away.

While it has some ViUR specific functions, it's also possible to use this wrapper outside ViUR.

Using

Just install it via venv, pipenv or requirements.txt into your appengine project. As by now it's a drop in replacement for the original library provided by google, but maybe we break api compatibility in a future release for more performance.

Developing

As a developer we want to have an editable viur-datastore library. We're going to use pipenv for the job and install needed

cd <path/to/viur-testing-project>
pipenv install
pipenv shell
pipenv install build twine
pipenv install -e <path/to/viur-datastore>

Choose a testing project configuration via gcloud if you use configs per projectIds:

gcloud config configurations activate <project-config>

Or use environment variable which projectId we want to use:

export CLOUDSDK_CORE_PROJECT="my-awesome-testing-project"

If the env var before does not work please set that one:

export GCLOUD_PROJECT="my-awesome-testing-project"

Yezzzz - now we build that awesome new stuff!:

python -m build

Please take a cup of tea - oh wait - it has just build in seconds. If everything worked fine, you should see some builds in the dist subfolder.

Testing

Now it's time run our test suite before actually releasing our shiny new version:

cd <path/to/viur-datastore>
python -m unittest tests

If everything worked fine and all tests passed you can go on with the release procedure.

Releasing

After building and testing the new version please update changelog, commit everything and tag it with the same version you used in setup.py.

Do you have already installed twine? No? Ok, go back to the developing step!!!

Now please manually bump the version in setup.py, safe the file and here we go.

We only want to provide and upload the generic build - perhaps we'll provide optimized builds per python version, OS and arch in a future release.

Now it's time to get an api key exclusively for this project from pypi and save it to your wallet!

Now the actual release workflow:

cd <path/to/viur-datastore>
twine upload dist/viur-datastore-<version>.tar.gz

You might already have a keyring configured with credentials /api key for pypi or provide username __token__ and password <your api key> in interactive mode.

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

viur_datastore-1.3.14.tar.gz (517.7 kB view details)

Uploaded Source

File details

Details for the file viur_datastore-1.3.14.tar.gz.

File metadata

  • Download URL: viur_datastore-1.3.14.tar.gz
  • Upload date:
  • Size: 517.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.9

File hashes

Hashes for viur_datastore-1.3.14.tar.gz
Algorithm Hash digest
SHA256 625060f1169909e763c28f1886c43498b3d73964fb4eeee8228cbfbb5ac375f4
MD5 42510a56e74d3c1d331d0d3adbec317c
BLAKE2b-256 5620cec0d6c3ddc037ec87d573e612bdd538b3df35e2bde672ebd5d860eb19eb

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