标签:缓存机制 响应 电脑 sts 中间 tag color obj res
首先我们先来了解下浏览器的缓存
浏览器缓存机制
在实际中开发应用中,我们会用到缓存,其实在django开发中我们也能用到缓存,现在django给我们很多缓存方式,我看到的有六种之多吧,可能其余的还有,不在追叙,我采用的是利用文件的缓存,说白了就是把缓存的数据放到请求的电脑中,这样也是减少一部分的服务器的压力,那么来看看我的配置。
CACHES = { ‘default‘: { ‘BACKEND‘: ‘django.core.cache.backends.filebased.FileBasedCache‘, ‘LOCATION‘: ‘/var/tmp/django_cache‘, } }
这是我们利用缓存文件的缓存,那么我们配置好了,来看下我们的使用,首先我们可以全局缓存
使用中间件,经过一系列的认证等操作,如果内容在缓存中存在,则使用FetchFromCacheMiddleware获取内容并返回给用户,
当返回给用户之前,判断缓存中是否已经存在,如果不存在则UpdateCacheMiddleware会将缓存保存至缓存,从而实现全站缓存
设置如下:
MIDDLEWARE = [ ‘django.middleware.cache.UpdateCacheMiddleware‘,#放到第一个中间件位置 # 其他中间件... ‘django.middleware.cache.FetchFromCacheMiddleware‘,#放到最后一个 ] CACHE_MIDDLEWARE_ALIAS = "" CACHE_MIDDLEWARE_SECONDS = "" CACHE_MIDDLEWARE_KEY_PREFIX = ""
还有就是我们对单独的视图进行缓存:
方法一:直接应用加入装饰器
from django.views.decorators.cache import cache_page
@cache_page(60*15) def ceshi(request): posts=Article.objects.filter(tag__name=u‘测试‘) post_list = fenye(request, posts=posts) return render(request, ‘index.html‘, {‘post_list‘: post_list,})
其实我还用到另外的方式,那就是在url处增加,因为我的是面向对象的编程方式所以我利用下面的。
url(r‘^$‘, cache_page(60*2)(HomeView.as_view()), name=‘home‘),
这样我们配置好,启动我们的项目,然后我们可以去看看我们的缓存是否生效,首先我们看下
可以看到,我在登陆界面做了两分钟的缓存,那么我们来看看我们的文件是否生效呢。
这样可以证明我们现在的缓存是成功的,其实我们还可以利用redis等来缓存。
标签:缓存机制 响应 电脑 sts 中间 tag color obj res
原文地址:http://www.cnblogs.com/leiziv5/p/7784524.html