我正在使用Django的每个视图@cache_page
装饰器,并为每个视图设置了不同的key_prefix
。
我之前删除了缓存:
from django.core.cache import cache
cache.clear()
但是如果我只想删除包含特定key_prefix
的密钥呢?我显然可以通过连接到数据库并使用原始sql删除来实现它,但我想知道是否可以使用' pure' Django的?
我使用的是数据库缓存,而不是内存缓存。
我正在使用Django 1.11和Python 3.6
答案 0 :(得分:5)
由于@ e4c5提到缓存用于快速的东西,你应该使用redis相同。但由于你的问题是关于数据库的,我会回答同样的问题。
在Django中没有现成的功能。但是,python的最佳部分是你可以轻松地添加新功能。以下是我创建的测试请求
def index(request):
cache.set("name", "tarun")
cache.set("name_1", "tarun")
cache.set("name2", "tarun")
cache.set("name_4", "tarun")
cache.set("nam", "tarun")
cache.clear(prefix="name")
nam = cache.get("nam")
name_4 = cache.get("name_4", default="deleted")
return HttpResponse("Hello, world. nam={nam}, name_4={name_4}".format(nam=nam, name_4=name_4))
要获得prefix
功能,您需要在某个地方添加以下补丁代码。我使用了settings.py
original_clear = None
def patch_clear():
from django.db import connections, router
from django.core.cache.backends.db import DatabaseCache
def __clear(self, prefix=None, version=None):
db = router.db_for_write(self.cache_model_class)
connection = connections[db]
table = connection.ops.quote_name(self._table)
with connection.cursor() as cursor:
if prefix is None:
cursor.execute('DELETE FROM %s ' % table)
else:
prefix = self.make_key(prefix, version)
cursor.execute("DELETE FROM %s where cache_key like '%s%%'" % (table, prefix))
global original_clear
original_clear = DatabaseCache.clear
DatabaseCache.clear = __clear
patch_clear()
答案 1 :(得分:3)
<强> TLDR 强>; cache.delete
和cache.delete_many
是您可以选择的选项。
答案很长。
@cache_page
评分过高。当您使用此装饰器时,您经常会发现缓存总是包含比预期更多的缓存条目。您最终想要删除一大堆缓存条目。这似乎正是这里发生的事情。
我使用的是数据库缓存,而不是内存缓存。
使用缓存的一个主要思想是减少服务器上的负载,另一个是减少昂贵的计算或数据库查询。但实际上,很多网页都没有昂贵的计算。通过仔细选择索引可以优化大多数慢查询。
如果数据库本身就是该缓存,则不会减少数据库的负载。如果您需要为不同的用户显示不同的内容,该怎么办?这非常复杂。
如果我只想删除包含特定内容的键,该怎么办? key_prefix?
考虑使用redis。这是django中最好的缓存后端之一(作为第三方模块)。能够在单个命令中删除多个键是redis的许多有用功能之一。