2014-09-28 01:49:36 +02:00
|
|
|
|
What’s new in django-cachalot?
|
|
|
|
|
==============================
|
|
|
|
|
|
2016-11-22 15:09:39 +01:00
|
|
|
|
1.4.2
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes cache in CachalotPanel
|
|
|
|
|
|
2016-10-24 20:44:32 +02:00
|
|
|
|
1.4.1
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes a circular import occurring when CachalotPanel is used
|
|
|
|
|
and django-debug-toolbar is before django-cachalot in ``INSTALLED_APPS``
|
|
|
|
|
- Stops checking compatibility for caches other than CACHALOT_CACHE
|
|
|
|
|
|
2016-09-29 20:28:47 +02:00
|
|
|
|
1.4.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes a bad design: ``QuerySet.select_for_update`` was cached, but it’s not
|
|
|
|
|
correct since it does not lock data in the database once data was cached,
|
|
|
|
|
leading to the database lock being useless in some cases
|
|
|
|
|
- Stops automatically invalidating other caches than ``CACHALOT_CACHE`` for
|
|
|
|
|
consistency, performance, and usefulness reasons
|
|
|
|
|
- Fixes a minor issue: the ``post_invalidation`` signal was sent during
|
|
|
|
|
transactions when calling the ``invalidate`` command
|
|
|
|
|
- Creates `a gitter chat room <https://gitter.im/django-cachalot/Lobby>`_
|
|
|
|
|
- Removes the Slack team. Slack does not allow public chat, this was therefore
|
|
|
|
|
a bad idea
|
|
|
|
|
|
2016-09-13 21:59:10 +02:00
|
|
|
|
1.3.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Adds Django 1.10 support
|
|
|
|
|
- Drops Django 1.7 support
|
|
|
|
|
- Drops Python 3.2 support
|
|
|
|
|
- Adds a Jinja2 extension with a ``cache`` statement
|
2016-09-29 20:28:47 +02:00
|
|
|
|
and the ``get_last_invalidation`` function
|
2016-09-13 21:59:10 +02:00
|
|
|
|
- Adds a ``CACHALOT_TIMEOUT`` setting after dozens
|
|
|
|
|
of private & public requests, but it’s not really useful
|
|
|
|
|
- Fixes a ``RuntimeError`` occurring if a ``DatabaseCache`` was used in
|
|
|
|
|
a project, even if not used by django-cachalot
|
|
|
|
|
- Allows bytes raw queries (except on SQLite where it’s not supposed to work)
|
|
|
|
|
- Creates `a Slack team <https://django-cachalot.slack.com>`_ to discuss,
|
|
|
|
|
easier than using Google Groups
|
|
|
|
|
|
2016-02-17 19:48:19 +01:00
|
|
|
|
1.2.1
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
**Mandatory update if you’re using django-cachalot 1.2.0.**
|
|
|
|
|
|
|
|
|
|
This version reverts the cache keys hashing change from 1.2.0,
|
|
|
|
|
as it was leading to a non-shared cache when Python used a random seed
|
|
|
|
|
for hashing, which is the case by default on Python 3.3, 3.4, & 3.5,
|
|
|
|
|
and also on 2.7 & 3.2 if you set ``PYTHONHASHSEED=random``.
|
|
|
|
|
|
2016-01-13 16:00:41 +01:00
|
|
|
|
1.2.0
|
|
|
|
|
-----
|
|
|
|
|
|
2016-02-17 19:48:19 +01:00
|
|
|
|
**WARNING: This version is unsafe, it can lead to invalidation errors**
|
|
|
|
|
|
2016-01-13 16:00:41 +01:00
|
|
|
|
- Adds Django 1.9 support
|
|
|
|
|
- Simplifies and speeds up cache keys hashing
|
|
|
|
|
- Documents how to use django-cachalot with a replica database
|
|
|
|
|
- Adds ``DummyCache`` to ``VALID_CACHE_BACKENDS``
|
|
|
|
|
- Updates the comparison with django-cache-machine & django-cacheops by
|
|
|
|
|
checking features and measuring performance instead of relying on their
|
|
|
|
|
documentations and a 2-years-ago experience of them
|
|
|
|
|
|
2015-10-28 19:17:39 +01:00
|
|
|
|
1.1.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
**Backwards incompatible changes:**
|
|
|
|
|
|
|
|
|
|
- Adds Django 1.8 support and drops Django 1.6 & Python 2.6 support
|
|
|
|
|
- Merges the 3 API functions ``invalidate_all``, ``invalidate_tables``,
|
|
|
|
|
& ``invalidate_models`` into a single ``invalidate`` function
|
|
|
|
|
while optimising it
|
|
|
|
|
|
|
|
|
|
Other additions:
|
|
|
|
|
|
|
|
|
|
- Adds a ``get_last_invalidation`` function to the API and the equivalent
|
|
|
|
|
template tag
|
|
|
|
|
- Adds a ``CACHALOT_ONLY_CACHABLE_TABLES`` setting in order to make a whitelist
|
|
|
|
|
of the only table names django-cachalot can cache
|
|
|
|
|
- Caches queries with IP addresses, floats, or decimals in parameters
|
|
|
|
|
- Adds a Django check to ensure the project uses
|
|
|
|
|
compatible cache and database backends
|
|
|
|
|
- Adds a lot of tests, especially to test django.contrib.postgres
|
|
|
|
|
- Adds a comparison with django-cache-machine and django-cacheops
|
|
|
|
|
in the documentation
|
|
|
|
|
|
|
|
|
|
Fixed:
|
|
|
|
|
|
|
|
|
|
- Removes a useless extra invalidation during each write operation
|
|
|
|
|
to the database, leading to a small speedup
|
|
|
|
|
during data modification and tests
|
|
|
|
|
- The ``post_invalidation`` signal was triggered during transactions
|
|
|
|
|
and was not triggered when using the API or raw write queries: both issues
|
|
|
|
|
are now fixed
|
|
|
|
|
- Fixes a very unlikely invalidation issue occurring only when an error
|
|
|
|
|
occurred in a transaction after a transaction of another database nested
|
|
|
|
|
in the first transaction was committed, like this:
|
|
|
|
|
|
|
|
|
|
.. code:: python
|
|
|
|
|
|
|
|
|
|
from django.db import transaction
|
|
|
|
|
|
|
|
|
|
assert list(YourModel.objects.using('another_db')) == []
|
|
|
|
|
|
|
|
|
|
try:
|
|
|
|
|
with transaction.atomic():
|
|
|
|
|
with transaction.atomic('another_db'):
|
|
|
|
|
obj = YourModel.objects.using('another_db').create(name='test')
|
|
|
|
|
raise ZeroDivisionError
|
|
|
|
|
except ZeroDivisionError:
|
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
|
# Before django-cachalot 1.1.0, this assert was failing.
|
|
|
|
|
assert list(YourModel.objects.using('another_db')) == [obj]
|
|
|
|
|
|
|
|
|
|
|
2015-06-19 21:27:45 +02:00
|
|
|
|
1.0.3
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes an invalidation issue that could rarely occur when querying on a
|
|
|
|
|
``BinaryField`` with PostgreSQL, or with some geographic queries
|
|
|
|
|
(there was a small chance that a same query with different parameters
|
|
|
|
|
could erroneously give the same result as the previous one)
|
|
|
|
|
- Adds a ``CACHALOT_UNCACHABLE_TABLES`` setting
|
|
|
|
|
- Fixes a Django 1.7 migrations invalidation issue in tests
|
|
|
|
|
(that was leading to this error half of the time:
|
|
|
|
|
``RuntimeError: Error creating new content types. Please make sure
|
|
|
|
|
contenttypes is migrated before trying to migrate apps individually.``)
|
|
|
|
|
- Optimises tests when using django-cachalot
|
|
|
|
|
by avoid several useless cache invalidations
|
|
|
|
|
|
|
|
|
|
|
2015-05-24 20:39:56 +02:00
|
|
|
|
1.0.2
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes an ``AttributeError`` occurring when excluding through a many-to-many
|
|
|
|
|
relation on a child model (using multi-table inheritance)
|
|
|
|
|
- Stops caching queries with random subqueries – for example
|
|
|
|
|
``User.objects.filter(pk__in=User.objects.order_by('?'))``
|
|
|
|
|
- Optimises automatic invalidation
|
|
|
|
|
- Adds a note about clock synchronisation
|
|
|
|
|
|
|
|
|
|
|
2015-04-17 20:44:39 +02:00
|
|
|
|
1.0.1
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes an invalidation issue discovered by Helen Warren that was occurring
|
|
|
|
|
when updating a ``ManyToManyField`` after executing using ``.exclude``
|
|
|
|
|
on that relation. For example, ``Permission.objects.all().delete()`` was not
|
|
|
|
|
invalidating ``User.objects.exclude(user_permissions=None)``
|
|
|
|
|
- Fixes a ``UnicodeDecodeError`` introduced with python-memcached 1.54
|
|
|
|
|
- Adds a ``post_invalidation`` signal
|
|
|
|
|
|
|
|
|
|
|
2015-03-15 18:15:43 +01:00
|
|
|
|
1.0.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
Fixes a bug occurring when caching a SQL query using a non-ascii table name.
|
|
|
|
|
|
|
|
|
|
|
2015-02-23 21:21:07 +01:00
|
|
|
|
1.0.0rc
|
|
|
|
|
-------
|
|
|
|
|
|
|
|
|
|
Added:
|
|
|
|
|
|
|
|
|
|
- Adds an `invalidate_cachalot` command to invalidate django-cachalot
|
|
|
|
|
from a script without having to clear the whole cache
|
|
|
|
|
- Adds the benchmark introduction, conditions & results to the documentation
|
|
|
|
|
- Adds a short guide on how to configure Redis as a LRU cache
|
|
|
|
|
|
|
|
|
|
Fixed:
|
|
|
|
|
|
|
|
|
|
- Fixes a rare invalidation issue occurring when updating a many-to-many table
|
|
|
|
|
after executing a queryset generating a ``HAVING`` SQL statement –
|
|
|
|
|
for example,
|
|
|
|
|
``User.objects.first().user_permissions.add(Permission.objects.first())``
|
|
|
|
|
was not invalidating
|
|
|
|
|
``User.objects.annotate(n=Count('user_permissions')).filter(n__gte=1)``
|
|
|
|
|
- Fixes an even rarer invalidation issue occurring when updating a many-to-many
|
|
|
|
|
table after executing a queryset filtering nested subqueries
|
|
|
|
|
by another subquery through that many-to-many table – for example::
|
|
|
|
|
|
|
|
|
|
User.objects.filter(
|
|
|
|
|
pk__in=User.objects.filter(
|
|
|
|
|
pk__in=User.objects.filter(
|
|
|
|
|
user_permissions__in=Permission.objects.all())))
|
|
|
|
|
- Avoids setting useless cache keys by using table names instead of
|
|
|
|
|
Django-generated table alias
|
|
|
|
|
|
|
|
|
|
|
2014-12-14 09:46:36 +01:00
|
|
|
|
0.9.0
|
|
|
|
|
-----
|
2014-10-29 15:12:38 +01:00
|
|
|
|
|
2014-12-08 22:00:08 +01:00
|
|
|
|
Added:
|
|
|
|
|
|
2014-11-24 19:11:37 +01:00
|
|
|
|
- Caches all queries implying ``Queryset.extra``
|
|
|
|
|
- Invalidates raw queries
|
2014-10-29 15:12:38 +01:00
|
|
|
|
- Adds a simple API containing:
|
2014-11-24 12:05:00 +01:00
|
|
|
|
``invalidate_tables``, ``invalidate_models``, ``invalidate_all``
|
2014-12-08 22:00:08 +01:00
|
|
|
|
- Adds file-based cache support for Django 1.7
|
|
|
|
|
- Adds a setting to choose if random queries must be cached
|
|
|
|
|
- Adds 2 settings to customize how cache keys are generated
|
|
|
|
|
- Adds a django-debug-toolbar panel
|
|
|
|
|
- Adds a benchmark
|
|
|
|
|
|
|
|
|
|
Fixed:
|
|
|
|
|
|
2014-11-24 19:11:37 +01:00
|
|
|
|
- Rewrites invalidation for a better speed & memory performance
|
2014-10-31 21:27:14 +01:00
|
|
|
|
- Fixes a stale cache issue occurring when an invalidation is done
|
2014-10-29 15:12:38 +01:00
|
|
|
|
exactly during a SQL request on the invalidated table(s)
|
2014-11-24 19:11:37 +01:00
|
|
|
|
- Fixes a stale cache issue occurring after concurrent transactions
|
2014-12-08 22:00:08 +01:00
|
|
|
|
- Uses an infinite timeout
|
|
|
|
|
|
|
|
|
|
Removed:
|
|
|
|
|
|
|
|
|
|
- Simplifies ``cachalot_settings`` and forbids its use or modification
|
2014-10-29 15:12:38 +01:00
|
|
|
|
|
|
|
|
|
|
2014-10-28 19:08:50 +01:00
|
|
|
|
0.8.1
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes an issue with pip if Django is not yet installed
|
|
|
|
|
|
|
|
|
|
|
2014-10-22 00:37:01 +02:00
|
|
|
|
0.8.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Adds multi-database support
|
|
|
|
|
- Adds invalidation when altering the DB schema using `migrate`, `syncdb`,
|
|
|
|
|
`flush`, `loaddata` commands (also invalidates South, if you use it)
|
|
|
|
|
- Small optimizations & simplifications
|
|
|
|
|
- Adds several tests
|
|
|
|
|
|
|
|
|
|
|
2014-10-19 21:52:09 +02:00
|
|
|
|
0.7.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Adds thread-safety
|
|
|
|
|
- Optimizes the amount of cache queries during transaction
|
|
|
|
|
|
2014-10-06 15:30:42 +02:00
|
|
|
|
0.6.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Adds memcached support
|
|
|
|
|
|
|
|
|
|
|
2014-10-05 03:29:00 +02:00
|
|
|
|
0.5.0
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Adds ``CACHALOT_ENABLED`` & ``CACHALOT_CACHE`` settings
|
|
|
|
|
- Allows settings to be dynamically overridden using ``cachalot_settings``
|
|
|
|
|
- Adds some missing tests
|
|
|
|
|
|
2014-10-01 22:17:47 +02:00
|
|
|
|
0.4.1
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
- Fixes ``pip install``.
|
|
|
|
|
|
2014-10-01 22:34:17 +02:00
|
|
|
|
0.4.0 (**install broken**)
|
|
|
|
|
--------------------------
|
2014-09-29 23:47:58 +02:00
|
|
|
|
|
|
|
|
|
- Adds Travis CI and adds compatibility for:
|
|
|
|
|
|
|
|
|
|
- Django 1.6 & 1.7
|
|
|
|
|
- Python 2.6, 2.7, 3.2, 3.3, & 3.4
|
|
|
|
|
- locmem & Redis
|
|
|
|
|
- SQLite, PostgreSQL, MySQL
|
|
|
|
|
|
2014-10-01 22:34:17 +02:00
|
|
|
|
0.3.0
|
|
|
|
|
-----
|
2014-09-29 20:05:50 +02:00
|
|
|
|
|
|
|
|
|
- Handles transactions
|
|
|
|
|
- Adds lots of tests for complex cases
|
|
|
|
|
|
2014-10-01 22:34:17 +02:00
|
|
|
|
0.2.0
|
|
|
|
|
-----
|
2014-09-28 01:49:36 +02:00
|
|
|
|
|
|
|
|
|
- Adds a test suite
|
|
|
|
|
- Fixes invalidation for data creation/deletion
|
|
|
|
|
- Stops caching on queries defining ``select`` or ``where`` arguments
|
|
|
|
|
with ``QuerySet.extra``
|
|
|
|
|
|
2014-10-01 22:34:17 +02:00
|
|
|
|
0.1.0
|
|
|
|
|
-----
|
2014-09-28 01:49:36 +02:00
|
|
|
|
|
|
|
|
|
Prototype simply caching all SQL queries reading the database
|
|
|
|
|
and trying to invalidate them when SQL queries modify the database.
|
|
|
|
|
|
|
|
|
|
Has issues invalidating deletions and creations.
|
|
|
|
|
Also caches ``QuerySet.extra`` queries but can’t reliably invalidate them.
|
|
|
|
|
No transaction support, no test, no multi-database support, etc.
|