Django生成静态页面和使用缓存
生成并使用静态页面
import os from django.shortcuts import render from django.template.loader import render_to_string def my_view(request): context = {'some_key': 'some_value'} static_html = '/path/to/static.html' if not os.path.exists(static_html): content = render_to_string('template.html', context, request) with open(static_html, 'w') as static_file: static_file.write(content) return render(request, static_html)
查看render代码发现,依然是执行了render_to_string读模板
def render(request, template_name, context=None, content_type=None, status=None, using=None): content = loader.render_to_string(template_name, context, request, using=using) return HttpResponse(content, content_type, status)
因此此可进一步优化为直接返回HttpResponse
import os from django.http import HttpResponse from django.shortcuts import render from django.template.loader import render_to_string def my_view(request): static_html = '/path/to/static.html' if os.path.exists(static_html): return render(request, static_html) else: context = {'some_key': 'some_value'} content = render_to_string('template.html', context, request) with open(static_html, 'w') as static_file: static_file.write(content) return HttpResponse(content)
使用Django Cache
但是一般情况下动态内容都不需要生成静态页面,频繁读写硬提升有限,因为Django 有更快的缓存功能
详细配置看官方文档
https://docs.djangoproject.com/zh-hans/3.2/topics/cache/#the-per-view-cache
settings
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.locmem.LocMemCache', # 使用本地内存作为缓存 'LOCATION': 'unique-snowflake', 'TIMEOUT': 3600, # 过期时间,None永不过期 } }
3.2 版后已移除MemcachedCache` 后端已被废弃,因为 python-memcached 有一些问题,而且似乎没有维护。
3.2 增加了 PyMemcacheCache
后端。
使用 PyMemcacheCache 或 PyLibMCCache 代替。
视图缓存
from django.views.decorators.cache import cache_page @cache_page(60 * 15) def my_view(request): return render(request, 'index.html')
URL缓存
from django.views.decorators.cache import cache_page urlpatterns = [ path('foo/<int:code>/', cache_page(60 * 15)(my_view)), ]
以上都可以自定义过期时间,但都有一个缺点,不能主动灵活删除。
底层缓存 API
def index(request): response = cache.get('index') if response is not None: return response context = {'some_key': 'some_value'} response = render(request, 'index.html', context) cache.set('index', response, 60*60) return response # 主动删除缓存 def delete_index(): cache.delete('index')