Flask SqlAlchemy router for stateful master-slave replication
Project description
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.
INSTALLATION
Install flask replicated distribution using pip install flask_replicated.
In flask app.config configure your database bindings a standard way:
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' }
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’])
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.changes_database decorator. It will mark function to always use master database url.
Conversely, wrap the view function with the @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
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
Hashes for flask_replicated-1.3-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 877d278b45d6de39189c6d076b71452d6d176e0d823c3f922922ba793546d36e |
|
MD5 | da031e0a54b2a40400c20dc10ab298a8 |
|
BLAKE2b-256 | 8777ccdfdf47da52f46c7f1373f11d36ad677ffccafdf511fa1b01f4b32b4cc6 |