我有一个memoized Django模型管理器方法如下:
class GroupManager(models.Manager):
def get_for_user(self, user):
cache_key = 'groups_%s' % (user.id)
if not hasattr(self, key):
groups = get_groups_somehow()
setattr(self, cache_key, groups)
return getattr(self, cache_key)
但是,记忆值仍然存在于请求/响应周期之外;即,在服务器重新启动之前,不会在后续请求中重新计算该值。这必须是因为管理器实例没有被销毁。
那么,我该如何正确地记忆模型管理器方法?
答案 0 :(得分:0)
键值不会重新计算,因为一旦键存在,您就不会重新计算键值。如果您想在后续调用中重新计算它,请重新排序代码
class GroupManager(models.Manager):
def get_for_user(self, user):
cache_key = 'groups_%s' % (user.id)
groups = get_groups_somehow()
setattr(self, cache_key, groups)
return getattr(self, cache_key)
如果您希望在不重新计算的情况下获得缓存的值,只需使用getattr
并在您的经理上使用正确的密钥。
答案 1 :(得分:0)
灵感来自https://stackoverflow.com/a/1526245/287923,但简化了它,我实现了一个请求缓存,如下所示:
from threading import currentThread
caches = {}
class RequestCache(object):
def set(self, key, value):
cache_id = hash(currentThread())
if caches.get(cache_id):
caches[cache_id][key] = value
else:
caches[cache_id] = {key: value}
def get(self, key):
cache_id = hash(currentThread())
cache = caches.get(cache_id)
if cache:
return cache.get(key)
return None
class RequestCacheMiddleware(object):
def process_response(self, request, response):
cache_id = hash(currentThread())
if caches.get(cache_id):
del(caches[cache_id])
return response
caches
是缓存字典的字典,可通过get
& set
方法。在呈现响应后,中间件在process_response
方法中清除当前线程的缓存。
它的使用方式如下:
from request_cache import RequestCache
cache = RequestCache()
cache.get(key)
cache.set(key, value)