Gui*_* IA 4 python django caching django-cache django-caching
我尝试使用 Django Cache 来改善我的观点。效果很好,400 毫秒到 8 毫秒是完美的。但是当用户第一次访问页面时,Django 会在标题中缓存包含用户信息的页面,当我尝试注销时,页面会继续包含用户信息。
我也尝试在模板中使用缓存,但效果不好,我的问题来自视图,所以继续 400ms。
我的设置.py
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
'LOCATION': 'unique-snowflake',
}
}
Run Code Online (Sandbox Code Playgroud)
我的看法.py
@cache_page(60 * 15)
def list(request, tag_slug=None):
page = request.GET.get('page')
data = questions_controller.list_questions(request, tag_slug, None, page)
if data:
return render(request, 'questions/list.html', data)
return page_not_found(request, "Page not found")
Run Code Online (Sandbox Code Playgroud)
我在按视图缓存时遇到了同样的问题。第一个缓存用户的用户信息向所有用户显示。而且我无法使用模板缓存,因为它很慢。
最好的方法是使用低级缓存 API缓存视图的最终结果。如果数据是动态的,则使用django-signals清除陈旧的缓存数据。根据您的要求调整以下代码。
浏览次数:
from django.core.cache import cache
def sample(request):
cached_data = cache.get_many(['query1', 'query2'])
if cached_data:
return render(request, 'sample.html', {'query1': cached_data['query1'], 'query2': cached_data['query2']})
else:
queryset1 = Model.objects.all()
queryset2 = Model2.objects.all()
cache.set_many({'query1': queryset1 , 'query2': queryset2 }, None)
return render(request, 'sample.html', {'query1': queryset1 , 'query2': queryset2})
Run Code Online (Sandbox Code Playgroud)
楷模:
from django.db.models.signals import post_save
from django.core.cache import cache
@receiver(post_save, sender=Model1)
@receiver(post_save, sender=Model2)
def purge_cache(instance, **kwargs):
cache.delete_many(['query1', 'query2'])
Run Code Online (Sandbox Code Playgroud)
希望这可以帮助。
| 归档时间: |
|
| 查看次数: |
3639 次 |
| 最近记录: |