Skip to main content

Flask SqlAlchemy router for stateful master-slave replication

Project description

https://img.shields.io/pypi/v/flask_replicated.svg

SUMMARY

Flask replicated is a Flask extension, designed to work with SqlAlchemy. It’s purpose it to provide more or less automatic master-slave replication. On each request, extension determines database usage intention (to read or to write into a database). Then, it picks right database url inside overriden db.get_engine() whenever request handler tries to access database depending on REST verb used.

Flask replicated comes with a security kill-switch to enable developper mode to easily keep control on the feature AUTO_READ_ON_SLAVE true by default, once deactivated only master database will be used unless explicit use of the decorators.

INSTALLATION

  1. Install flask replicated distribution using pip install flask_replicated. Or add flask-replicated==1.4 in requirements.txt and requirements pip3 install -r requirements.txt.

  2. Import library from flask_replicated import FlaskReplicated or import flask_replicated depending on how you want to call the functions or decorators

  3. In flask app.config configure your database bindings a standard way:

    AUTO_READ_ON_SLAVE = True
    SQLALCHEMY_DATABASE_URI = '%(schema)s://%(user)s:%(password)s@%(master_host)s/%(database)s'
    SQLALCHEMY_BINDS = {
        'master': SQLALCHEMY_DATABASE_URI,
        'slave': '%(schema)s://%(user)s:%(password)s@%(slave_host)s/%(database)s'
    }
  4. Register app extension:

    app = Flask(...)
    ...
    FlaskReplicated(app)

USAGE

Flask replicated routes SQL queries into different databases based on request method. If method is one of READONLY_METHODS which are defined as set([‘GET’, ‘HEAD’]) and config AUTO_READ_ON_SLAVE has not been set

While this is usually enough there are cases when DB access is not controlled explicitly by your business logic. Good examples are implicit creation of sessions on first access, writing some bookkeeping info, implicit registration of a user account somewhere inside the system. These things can happen at arbitrary moments of time, including during GET requests.

To handle these situations wrap appropriate view function with @flask_replicated.use_master_database decorator. It will mark function to always use master database url.

Conversely, wrap the view function with the @flask_replicated.use_slave_database decorator if you want to ensure that it always uses the slave replica.

GET after POST

There is a special case that needs addressing when working with asynchronous replication scheme. Replicas can lag behind a master database on receiving updates. In practice this mean that after submitting a POST form that redirects to a page with updated data this page may be requested from a slave replica that wasn’t updated yet. And the user will have an impression that the submit didn’t work.

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

flask_replicated-2.1.tar.gz (3.1 kB view details)

Uploaded Source

Built Distribution

flask_replicated-2.1-py3-none-any.whl (3.5 kB view details)

Uploaded Python 3

File details

Details for the file flask_replicated-2.1.tar.gz.

File metadata

  • Download URL: flask_replicated-2.1.tar.gz
  • Upload date:
  • Size: 3.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.6.8

File hashes

Hashes for flask_replicated-2.1.tar.gz
Algorithm Hash digest
SHA256 52313a8ac28088d076e1cbb0971493ec08ed8e29089a3b03639b86496b3f3d0e
MD5 a296da59cd97a17ede694cbf4d786144
BLAKE2b-256 80804d84ae859fafee2706dd344abda17da7822d36967a4f1533e21feda6c86b

See more details on using hashes here.

File details

Details for the file flask_replicated-2.1-py3-none-any.whl.

File metadata

  • Download URL: flask_replicated-2.1-py3-none-any.whl
  • Upload date:
  • Size: 3.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.8.1 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.6.8

File hashes

Hashes for flask_replicated-2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b393d23e0360ef57e58fb04aeb22273df2c8d756e517883f4419b0d6ce143d97
MD5 014b02dca189ed5021cd816ac1e1613c
BLAKE2b-256 ae84558814bb1ce39e40f9c004ab26eadd2065ed6b8e1b8e3c0cfe856cc5c619

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