-
Notifications
You must be signed in to change notification settings - Fork 1
License
martinphellwig/django-memdb
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
.. image:: https://img.shields.io/codeship/a9873030-5c43-0134-5e91-46e8172ca5a4/default.svg :target: https://bitbucket.org/hellwig/django-memdb .. image:: https://coveralls.io/repos/bitbucket/hellwig/django-memdb/badge.svg?branch=default :target: https://coveralls.io/bitbucket/hellwig/django-memdb?branch=default .. image:: https://img.shields.io/pypi/v/django-memdb.svg :target: https://pypi.python.org/pypi/Django-MemDB/ .. image:: https://img.shields.io/badge/Donate-PayPal-blue.svg :target: https://paypal.me/MartinHellwig .. image:: https://img.shields.io/badge/Donate-Patreon-orange.svg :target: https://www.patreon.com/hellwig ###################### Django Memory Database ###################### What is it? =========== A library that allows tables to be kept in an in-memory database and optionally can provide persistence between instance restart by spooling the tables to a table that is read upon startup to populate the in-memory tables. What problem does it solve? =========================== Create in-memory tables with optional data persistence. How do I install it? ==================== .. sourcecode:: shell pip install django-memdb Adding to Django (using integrator) ----------------------------------- .. sourcecode:: python # At the bottom of your settings.py file. import django_integrator django_integrator.add_application('django_memdb') If you don't want to use the above, add the application to INSTALLED_APPS and merge the apps settings.py and url.py into the django projects files. How do I use it? ================ When defining models, use the class mixin. For example: .. sourcecode:: python from django.db import models from django_memdb.mixins import InMemoryDB, PeristentInMemoryDB class TestModelWithMixin(models.Model, InMemoryDB): text = models.TextField() class TestModelPersistent(models.Model, PeristentInMemoryDB): text = models.TextField() Both mixins work more like a tag, which is used to determine if a table is an in-memory table or not and if the table contents should be stored in the (using the default database) PersistentStorage model. You can optionally hook into the persistentstorage mechanics by attaching to the signals this app provides. The below example will add compression the data before storing it: .. sourcecode:: python from django_memdb import signals def compress(arguments): "Compress data." # pylint: disable=redefined-variable-type if arguments['process'] == settings.MEMDB_PROCESS_ENCODE: data = arguments['data'] data = json.dumps(data) data = data.encode('utf-8') data = zlib.compress(data) arguments['data'] = data elif arguments['process'] == settings.MEMDB_PROCESS_DECODE: data = arguments['data'] data = zlib.decompress(data) data = data.decode('utf-8') data = json.loads(data) arguments['data'] = data def callback(sender, **kwargs): # pylint: disable=unused-argument "Just insert a hook." kwargs['kwargs']['processors'].append(compress) signals.store_save.connect(callback) signals.store_load.connect(callback) Caveat ====== The in memory database is local to each server instance, thus if you have a setup that uses multiple servers and a single django database instance, you will have synchronisation issues with the in-memory data and hard conflicts when using the persistent storage. What license is this? ===================== Two-clause BSD How can I get support? ====================== Please use the repo's bug tracker to leave behind any questions, feedback, suggestions and comments. I will handle them depending on my time and what looks interesting. If you require guaranteed support please contact me via e-mail so we can discuss appropriate compensation. Signing Off =========== Is my work helpful or valuable to you? You can repay me by donating via: https://paypal.me/MartinHellwig .. image:: https://img.shields.io/badge/PayPal-MartinHellwig-blue.svg :target: https://paypal.me/MartinHellwig :alt: Donate via PayPal.Me :scale: 120 % -or- https://www.patreon.com/hellwig .. image:: https://img.shields.io/badge/Patreon-hellwig-orange.svg :target: https://www.patreon.com/hellwig :alt: Donate via Patreon :scale: 120 % Thank you!
About
No description, website, or topics provided.
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published