Django Cache 缓存组件

在FBV 或 CBV 需要缓存数据,又或者要进行全站缓存(利用中间件),单视图缓存(利用装饰器@cache_page(60 * 5) ),或者在template中使用{% cache 5 content_detail %} xxx {% endcache %} 进行页面局部缓存。这些场景都是需要用到缓存,来提高我们响应用户请求速度的。在django框架中,给我们提供了Cache组件,并暴露出满足以上4中需求的接口,我们只需要配置好我们的缓存引擎源及相关配置,就可以方便使用了。

博文图片挂了临时解决办法

缓存逻辑伪代码


given a URL, try finding that page in the cache
if the page is in the cache:
return the cached page
else:
generate the page
save the generated page in the cache (for next time)
return the generated page

配置缓存源

在配置settings.py中CACHES = {} 字典中, 添加缓存源,key为缓存源的别名,django默认给我们提供了一个默认缓存,并且是LocMemCahce即memcahe作为缓存引擎。当然可以配置多个缓存源,但是'default'只有一个,这个是默认使用的。当然默认的也可以替换,比如现在流行用reids作为默认缓存。

可配置参数说明

查看官网: cache配置参数说明, hint 这里!

01. Django的默认缓存


CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
'LOCATION': 'unique-snowflake'
}
}

该缓存引擎,对每一个进程是一个缓存,所以该缓存时线程安全的。(This cache is per-process (see below) and thread-safe.)

'LOCATION'设置时用于标识独立的内存存储。如果系统只有一个,那么可以忽略该设置。

由于时每个进程一个缓存实例,所以如果多线程或多进程,那么缓存的使用上就不是很高效,所以该缓存引擎不是非常适合生产环境,适合dev环境。

02. 基于Redis的django-redis

  • 安装django-redis
# 通过pip安装
>>> pip install django-redis
# 通过pipenv 安装
>>> pyenv install django-redis
  • 安装django-redis就会依赖安装redis.py
  • 将默认的CACHES设置为django-redis并配置redis-server相关信息

    django-redis连接到redis-server使用的是redis连接池。

    所以django-redis也提供了一个接口,供我们直接从连接池中拿到redis连接,然后使用redis (get_redis_connection('default'));注意这种方式不是django cache组件提供的接口操作redis方式,这种方式是low-level的;而django cache组件则是在low-level基础上封装的更高级的接口,供我们使用。
  • 安装完成django-redis后,配置为默认cache源:
CACHES = {
'default': {
'BACKEND': 'django_redis.cache.RedisCache',
'LOCATION': 'redis://127.0.0.1:6379',
'OPTIONS': {
'CLIENT_CLASS': 'django_redis.client.DefaultClient',
'CONNECTION_POOL_KWARGS': {
'max_connections': 1000
},
# 'PASSWORD': 'xxx', # 如果有设置了redis-server密码在这里设置
}
}
}

03. 自定义cache

可以查看django_redis.cache.RedisCache 都是继承了from django.core.cache.backends.base import BaseCache ,所以在django中高级的缓存操作都是通过BaseCache中定义的接口。

所以自定义cache backend 可以通过继承django.core.cache.backends.base.BaseCache 接口,然后实现接口中的方法。就可以将自己的backend配置到django中使用了。

04. Django其它内置的缓存源,直接开箱使用out-of-the-box

django内置的cache backend:

使用cache的示例

Tips: 通过redis-cli 查看所有库的key统计信息,命令是info keyspace;

1. cache在视图中示例

# 引入装饰器装饰视图函数即可缓存视图
from django.views.decorators.cache import cache_page
  • FBV视图缓存
import time
from django.views.decoratosr.cache import cache_page @chace_page(60*5) # 必须设置缓存的更新间隔,单位秒
def content_detail(request):
return HTTPResponse('hello' + str(time.time()))
  • CBV视图缓存

    特别注意:CBV的视图缓存使用cache_page()是放入URLConf中,而不是对get或者post等CBV内的方法进行装饰。

2. 全站缓存

在配置文件的中间件列表的首尾分别添加如下中间件:


MIDDLEWARE = [
'django.middleware.cache.UpdateCacheMiddleware',
......
'django.middleware.common.CommonMiddleware',
......
'django.middleware.cache.FetchFromCacheMiddleware',]

3. 利用模板系统页面部分缓存

{% load cache %}
{% cache 500 sidebar %}
.. sidebar ..
{% endcache %}

4. low-level api操作缓存

通过cache对象的api直接操作缓存。

  • 首先,拿到cache对象:
from django.core.cache import caches  #这是所有设置的cache对象的字典
from django.core.cache import cache # 这是”default" 默认的cahce对象 my_cache = caches['mycache']
my_cache.set('k1', 'abc', 30) # 设置k1 值为 ’abc' 有效期 30s.

Note: 注意,每个process 获取的 cache instance 都是独立的,不是同一个,为保证线程安全。

总结

  1. 参考:https://docs.djangoproject.com/en/2.1/topics/cache/#the-per-view-cache
  2. 从cache的backend引擎,将cache抽象出来,定义出cache的接口,实现细节各自引擎处理。
  3. 看到一句话: 抽象比细节活的更长久.

Django学习之十二:Cache 缓存组件的更多相关文章

  1. Django学习之十: staticfile 静态文件

    目录 Django学习之十: staticfile 静态文件 理解阐述 静态文件 Django对静态文件的处理 其它方面 总结 Django学习之十: staticfile 静态文件 理解阐述     ...

  2. 任务四十二:UI组件之日历组件(三)

    任务四十二:UI组件之日历组件(三) 面向人群: 有一定基础的同学 难度: 困难 重要说明 百度前端技术学院的课程任务是由百度前端工程师专为对前端不同掌握程度的同学设计.我们尽力保证课程内容的质量以及 ...

  3. python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL

    python3.4学习笔记(十二) python正则表达式的使用,使用pyspider匹配输出带.html结尾的URL实战例子:使用pyspider匹配输出带.html结尾的URL:@config(a ...

  4. Go语言学习笔记十二: 范围(Range)

    Go语言学习笔记十二: 范围(Range) rang这个关键字主要用来遍历数组,切片,通道或Map.在数组和切片中返回索引值,在Map中返回key. 这个特别像python的方式.不过写法上比较怪异使 ...

  5. Django学习笔记(二):使用Template让HTML、CSS参与网页建立

    Django学习笔记(二):使用Template让HTML.CSS参与网页建立 通过本文章实现: 了解Django中Template的使用 让HTML.CSS等参与网页建立 利用静态文件应用网页样式 ...

  6. Tensorflow深度学习之十二:基础图像处理之二

    Tensorflow深度学习之十二:基础图像处理之二 from:https://blog.csdn.net/davincil/article/details/76598474   首先放出原始图像: ...

  7. 微信小程序把玩(二十二)action-sheet组件

    原文:微信小程序把玩(二十二)action-sheet组件 action-sheet组件是从底部弹出可选菜单项,估计也是借鉴IOS的设计添加的,action-sheet有两个子组件, action-s ...

  8. 微信小程序把玩(十二)text组件

    原文:微信小程序把玩(十二)text组件 通常文本设置要不在wxml中设置,再要不就是通过weml绑定在js中设置文字. wxml <view > <text>我是文本组件&l ...

  9. Django框架(十四)-- forms组件、局部钩子、全局钩子

    一.什么是forms组件 forms组件就是一个类,可以检测前端传来的数据,是否合法. 例如,前端传来的邮箱数据,判断邮件格式对不对,用户名中不能以什么开头,等等 二.forms组件的使用 1.使用语 ...

随机推荐

  1. DOM4J熟知

    什么是解析xml 系统最终会从xml中读取数据. 读取的过程就是解析. CRUD ==> 增删改查 ==> create read update delete ==> 解析指的就是读 ...

  2. 云计算一:VMware workstation的安装和使用教程

    VMware workstation的安装和使用教程 一.VMware 安装 1.从网上找到VMware的安装包以及要安装的映像文件,下载到本地,然后备份一份存储到百度云盘. 链接:http://pa ...

  3. spring cloud 入门系列七:基于Git存储的分布式配置中心

    我们前面接触到的spring cloud组件都是基于Netflix的组件进行实现的,这次我们来看下spring cloud 团队自己创建的一个全新项目:Spring Cloud Config.它用来为 ...

  4. 并发库应用之五 & ReadWriteLock场景应用

    Lock比传统线程模型中的synchronized方式更加面向对象,与生活中的锁类似,锁本身也应该是一个对象.两个线程执行的代码片段要实现同步互斥的效果,它们必须用同一个Lock对象. 读写锁:分为读 ...

  5. PAT1040:Longest Symmetric String

    1040. Longest Symmetric String (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, ...

  6. MySql 物理文件组成

    1.日志文件        MySQL 各类日志文件介绍 2.数据文件        MySQL 各类数据文件介绍

  7. springboot+activemq中引入重发机制

    一.简介 在使用activemq消息中间件进行消息队列传输时,总会由于各种原因导致消息失败. 一个经典的场景是一个生成者向Queue中发消息,里面包含了一组邮件地址和邮件内容.而消费者从Queue中将 ...

  8. JavaScript 异步开发全攻略(转)

    写了一本介绍 JavaScript 异步开发的小书: https://meathill.gitbooks.io/javascript-async-tutorial/content/ 除了比较详细的介绍 ...

  9. centos环境的python、scrapy部署

    1 操作系统 Centos 6.5 64bit 或以上版本 2 软件环境 提示:(1)用什么软件:(2)运行环境(3)开发包. Python:Python-2.7.6.tgz Scrapy:Scrap ...

  10. Linux用户和组管理,添加修改用户,添加修改组,加入组,移除组

    1.安全介绍3A Authentication: 认证,用户名和对应口令 Authorization: 授权,不同用户权限不同 Accouting/Audition: 审计 2. 所属者和所属组 us ...