Django进阶(中间件缓存)
Posted Captain
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Django进阶(中间件缓存)相关的知识,希望对你有一定的参考价值。
中间件概念
中间件是嵌入django 的 request/response 处理过程的一套钩子框架。它是一个轻量级的底层嵌入系统,可以对 django 的输入输出做整体的修改。
使用场景:
比如我们写一个判断浏览器来源,是pc还是手机;判断来源IP是哪个地区,禁用该地区访问
django 中的中间件(middleware),在django中,中间件其实就是一个类,在请求到来和结束后,django会根据自己的规则在合适的时机执行中间件中相应的方法。
在django项目的settings模块中,有一个 MIDDLEWARE 变量,其中每一个元素就是一个中间件
每一个中间件中都可以定义四个方法,分别是:
process_request(self,request)
process_view(self, request, callback, callback_args, callback_kwargs) 在本次将要执行的View函数被调用前调用本函数
process_exception(self, request, exception) View函数在抛出异常时该函数被调用
process_response(self, request, response) 在执行完View函数准备将响应发到客户端前被执行
以上方法的返回值可以是None和HttpResonse对象,如果是None,则继续按照django定义的规则向下执行,如果是HttpResonse对象,则直接将该对象返回给用户。
自定义中间件
middle1.py文件:
from django.utils.deprecation import MiddlewareMixin class mmm(MiddlewareMixin): def process_request(self, request): print \'mmm.process_request\' def process_view(self, request, callback, callback_args, callback_kwargs): print \'mmm.process_view\' def process_response(self, request, response): print \'mmm.process_response\' return response class xxx(MiddlewareMixin): def process_request(self, request): print \'xxx.process_request\' def process_view(self, request, callback, callback_args, callback_kwargs): print \'xxx.process_view\' def process_response(self, request, response): print \'xxx.process_response\' return response
访问某个视图时,执行顺序如下:
缓存
由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用:缓存
缓存将一个某个views的返回值保存至内存或者memcache中,X分钟内再有人来访问时,则不再去执行view中的操作,而是直接从内存或者Redis中之前缓存的内容拿到,并返回
Django中提供了6种缓存方式:
开发调试
内存
文件
数据库
Memcache缓存(python-memcached模块)
Memcache缓存(pylibmc模块)
setting文件配置:
# 此缓存将内容保存至 内存 的变量中 # 配置: CACHES = { \'default\': { \'BACKEND\': \'django.core.cache.backends.locmem.LocMemCache\', \'LOCATION\': \'unique-snowflake\', } }
# 此缓存将内容保存至 文件 # 配置: CACHES = { \'default\': { \'BACKEND\': \'django.core.cache.backends.filebased.FileBasedCache\', \'LOCATION\': \'/var/tmp/django_cache\', } }
# 此缓存将内容保存至数据库 # 配置: CACHES = { \'default\': { \'BACKEND\': \'django.core.cache.backends.db.DatabaseCache\', \'LOCATION\': \'my_cache_table\', # 数据库表 } }
使用方法:
1、全站使用
使用中间件,经过一系列的认证等操作,如果内容在缓存中存在,则使用FetchFromCacheMiddleware获取内容并返回给用户,当返回给用户之前,判断缓存中是否已经存在,如果不存在则UpdateCacheMiddleware会将缓存保存至缓存,从而实现全站缓存 MIDDLEWARE = [ \'django.middleware.cache.UpdateCacheMiddleware\', # 其他中间件... \'django.middleware.cache.FetchFromCacheMiddleware\', ] CACHE_MIDDLEWARE_ALIAS = "" CACHE_MIDDLEWARE_SECONDS = "" CACHE_MIDDLEWARE_KEY_PREFIX = ""
2、单独视图缓存
方式一: from django.views.decorators.cache import cache_page @cache_page(60 * 15) def my_view(request): ... 方式二: from django.views.decorators.cache import cache_page urlpatterns = [ url(r\'^foo/([0-9]{1,2})/$\', cache_page(60 * 15)(my_view)), ]
3、局部视图使用
a. 引入TemplateTag {% load cache %} b. 使用缓存 {% cache 5000 缓存key %} 缓存内容 {% endcache %}
以上是关于Django进阶(中间件缓存)的主要内容,如果未能解决你的问题,请参考以下文章
Python入门自学进阶-Web框架——19Django其他相关知识