Provide hints to optimize database usage by deferring unused fields
Project description
=============================
Django Eraserhead
=============================
.. image:: https://badge.fury.io/py/django-eraserhead.svg
:target: https://badge.fury.io/py/django-eraserhead
.. image:: https://travis-ci.org/dizballanze/django-eraserhead.svg?branch=master
:target: https://travis-ci.org/dizballanze/django-eraserhead
.. image:: https://codecov.io/gh/dizballanze/django-eraserhead/branch/master/graph/badge.svg
:target: https://codecov.io/gh/dizballanze/django-eraserhead
Provide hints to optimize database usage by deferring unused fields
.. image:: https://github.com/dizballanze/django-eraserhead/raw/master/eraserhead.jpg
*WARNING* use this package only in dev environment!
Documentation
-------------
Requirements
-----------
* Django 1.9+
* Python 2.7, 3.4+
Quickstart
----------
Install Django Eraserhead::
pip install django-eraserhead
Add it to your `INSTALLED_APPS`:
.. code-block:: python
INSTALLED_APPS = (
...
'eraserhead.apps.EraserheadConfig',
...
)
ERASERHEAD_ENABLED = True
ERASERHEAD_TRACEBACK_BASE_PATH = BASE_DIR
Settings:
* `ERASERHEAD_ENABLED` - enable/disable Django Eraserhead
* `ERASERHEAD_TRACEBACK_BASE_PATH` - set base path to filter tracebacks. Set to `None` to display full traceback.
Features
--------
.. image:: https://github.com/dizballanze/django-eraserhead/raw/master/screenshot.png
Django Eraserhead monitors:
* querysets/models fields usage (used and unused fields) with considering deferred fields
* count of instances created for each queryset
* corresponding model of each queryset
* traceback for each queryset to easily find corresponding code
Based on fields usage Django Eraserhead suggests optimizations for each queryset.
TODO
-----
* calculate memory consumption of unused fields
* decorator and/or context processor for partial stats collecting
* detect deferred fields loading
* auto deferring fields based on usage
* display deferred fields
Running Tests
-------------
::
source <YOURVIRTUALENV>/bin/activate
(myenv) $ pip install tox
(myenv) $ tox
Credits
-------
Tools used in rendering this package:
* Cookiecutter_
* `cookiecutter-djangopackage`_
.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`cookiecutter-djangopackage`: https://github.com/pydanny/cookiecutter-djangopackage
Django Eraserhead
=============================
.. image:: https://badge.fury.io/py/django-eraserhead.svg
:target: https://badge.fury.io/py/django-eraserhead
.. image:: https://travis-ci.org/dizballanze/django-eraserhead.svg?branch=master
:target: https://travis-ci.org/dizballanze/django-eraserhead
.. image:: https://codecov.io/gh/dizballanze/django-eraserhead/branch/master/graph/badge.svg
:target: https://codecov.io/gh/dizballanze/django-eraserhead
Provide hints to optimize database usage by deferring unused fields
.. image:: https://github.com/dizballanze/django-eraserhead/raw/master/eraserhead.jpg
*WARNING* use this package only in dev environment!
Documentation
-------------
Requirements
-----------
* Django 1.9+
* Python 2.7, 3.4+
Quickstart
----------
Install Django Eraserhead::
pip install django-eraserhead
Add it to your `INSTALLED_APPS`:
.. code-block:: python
INSTALLED_APPS = (
...
'eraserhead.apps.EraserheadConfig',
...
)
ERASERHEAD_ENABLED = True
ERASERHEAD_TRACEBACK_BASE_PATH = BASE_DIR
Settings:
* `ERASERHEAD_ENABLED` - enable/disable Django Eraserhead
* `ERASERHEAD_TRACEBACK_BASE_PATH` - set base path to filter tracebacks. Set to `None` to display full traceback.
Features
--------
.. image:: https://github.com/dizballanze/django-eraserhead/raw/master/screenshot.png
Django Eraserhead monitors:
* querysets/models fields usage (used and unused fields) with considering deferred fields
* count of instances created for each queryset
* corresponding model of each queryset
* traceback for each queryset to easily find corresponding code
Based on fields usage Django Eraserhead suggests optimizations for each queryset.
TODO
-----
* calculate memory consumption of unused fields
* decorator and/or context processor for partial stats collecting
* detect deferred fields loading
* auto deferring fields based on usage
* display deferred fields
Running Tests
-------------
::
source <YOURVIRTUALENV>/bin/activate
(myenv) $ pip install tox
(myenv) $ tox
Credits
-------
Tools used in rendering this package:
* Cookiecutter_
* `cookiecutter-djangopackage`_
.. _Cookiecutter: https://github.com/audreyr/cookiecutter
.. _`cookiecutter-djangopackage`: https://github.com/pydanny/cookiecutter-djangopackage
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
Built Distribution
File details
Details for the file django-eraserhead-0.1.4.tar.gz
.
File metadata
- Download URL: django-eraserhead-0.1.4.tar.gz
- Upload date:
- Size: 6.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c0ce79a46861631a6cce8c0820d5554c1a6264df9afaff9386734d9e687be0a8 |
|
MD5 | 0d5daeb90d1832391525c21583c1148c |
|
BLAKE2b-256 | 9772e8834039338ca3c0d56b83a49b484a5a1612d4a6d344abd5372b435a0946 |
File details
Details for the file django_eraserhead-0.1.4-py2.py3-none-any.whl
.
File metadata
- Download URL: django_eraserhead-0.1.4-py2.py3-none-any.whl
- Upload date:
- Size: 7.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 01691c9bf2590df77679c9e6b912eec77f180f421b2b2663711ba2d4683bccba |
|
MD5 | 18b01c400d44b6152f5baa8162cf989d |
|
BLAKE2b-256 | efefe9c8ffd4cdb426fc12ef215341e3a5103e93a9aa3b9326dc144b80dfa391 |