#32747 closed Bug (fixed)
CacheHandler initialize unused caches.
Reported by: | Alexander Ebral | Owned by: | Mariusz Felisiak |
---|---|---|---|
Component: | Core (Cache system) | Version: | 3.2 |
Severity: | Release blocker | Keywords: | |
Cc: | Florian Apolloner | Triage Stage: | Accepted |
Has patch: | yes | Needs documentation: | no |
Needs tests: | no | Patch needs improvement: | no |
Easy pickings: | no | UI/UX: | no |
Description
After the commit: https://github.com/django/django/commit/98e05ccde440cc9b768952cc10bc8285f4924e1f
logic of the method "all" from CacheHandler class was changed.
Before:
def all(self): return getattr(self._caches, 'caches', {}).values()
This method returned connections that were created in __getitem__
Now:
def all(self): return [self[alias] for alias in self]
Connections return for all "CACHES" from settings.py (in case of absence - they are forcibly created in self[alias])
Which version of this method seems to be right?
In my case this unnecessary mass initialization of custom diskcache-classes leads to io-lags.
Snippet that helped me:
import django.core.cache def cache_getitem(self, alias, exists_only=False): try: return getattr(self._connections, alias) except AttributeError: if alias not in self.settings: raise self.exception_class(f"The connection '{alias}' doesn't exist.") if exists_only: return conn = self.create_connection(alias) setattr(self._connections, alias, conn) return conn def cache_all(self): connections = [self.__getitem__(alias, exists_only=True) for alias in self] return [conn for conn in connections if conn is not None] django.core.cache.CacheHandler.all = cache_all django.core.cache.CacheHandler.__getitem__ = cache_getitem
Change History (5)
comment:1 by , 4 years ago
Cc: | added |
---|---|
Severity: | Normal → Release blocker |
Summary: | CacheHandler logic issue → CacheHandler initialize unused caches. |
Triage Stage: | Unreviewed → Accepted |
comment:2 by , 4 years ago
Owner: | changed from | to
---|---|
Status: | new → assigned |
Thanks for the report. I agree this can cause a performance regression, we shouldn't initialize unused caches unnecessarily. As far as I'm aware we can restore the previous behavior with:
Regression in 98e05ccde440cc9b768952cc10bc8285f4924e1f.