Django页面数据的缓存与使用的具体方法
为什么要使用缓存?
一个动态网站的基本权衡点就是,它是动态的。 每次用户请求页面,服务器会重新计算。从开销处理的角度来看,这比你读取一个现成的标准文件的代价要昂贵的多
使用缓存,将多用户访问时基本相同的数据先缓存起来;这样当用户访问页面的时候,不需要重新计算数据,而是直接从缓存里读取,避免性能上的开销。
使用redis数据库
使用redis数据库存储缓存,首先redis是key-value类型的数据库,nosql,且也是内存型数据库,redis是将数据加载到内存中,进行操作,并异步将数据备份到硬盘里。而我们知道,内存的读取速度要比硬盘的读取速度快,因此redis的读取速度要比其他文件型数据库快很多。
配置django的缓存设置
settings.py中添加:
caches = { "default": { "backend": "django_redis.cache.rediscache", "location": "redis://172.16.3.241:6379/9", //指向装有redis的服务器ip地址:端口 /9表示使用db9 "options": { "client_class": "django_redis.client.defaultclient", } } }
使用django内置的缓存api (cache)
导入 from django.core.cache import cache
例子
在视图类或视图函数中, 首先先别急着计算页面数据;而是先向缓存读取该页面的数据;若返回一个 none;说明没有缓存或缓存的数据已经过期;此时才需要进行数据库查询等计算服务
并将更新后的数据写入缓存中,自始至终同一页面都统一使用一个 key进行存取或删除;
# 缓存的设置与获取 伪代码: content= cache.get(‘index_data') if content is none: 查询数据等 cache.set(‘index_data',content,timeout) # 设置缓存 # 渲染页面
缓存设置了过期时间timeout,单位为秒,当到达过期时间之后,该缓存的数据将不会被使用,以此来确保缓存数据不会一直都是同一份。
但假如我设定timeout为3600,即60分钟,那么在60分钟内,如网页的数据被更新了,而用户访问时只能显示旧的页面数据,因此为了保证缓存的时效性,
可以在数据更改时删除旧缓存。
如在django自带的管理页面中,当模型发生修改时,会默认调用admin.modeladmin的save_model 或 delete_model 方法。因此,继承并重写该方法,并在里面添加
删除缓存的代码,则网站管理员通过自带管理页面修改数据时,旧的页面缓存会被清除
如:
class basemodel(admin.modeladmin): ''' 继承admin.modeladmin 重写save_model / delete_model 方法 ''' def save_model(self, request, obj, form, change): super().save_model(request,obj,form,change) # 删除首页缓存 cache.delete('index_data') # 删除类型和新品推荐的缓存 cache.delete('types_and_newsku') def delete_model(self, request, obj): super().delete_model(request,obj) #删除首页缓存 cache.delete('index_data') # 删除类型和新品推荐的缓存 cache.delete('types_and_newsku')
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
对sklearn的使用之数据集的拆分与训练详解(python3.6)
-
使用sessionStorage解决vuex在页面刷新后数据被清除的问题
-
angular2中router路由跳转navigate的使用与刷新页面问题详解
-
jQuery中ajax的使用与缓存问题的解决方法
-
浅谈django三种缓存模式的使用及注意点
-
C#_Excel数据读取与写入_自定义解析封装类_支持设置标题行位置&使用excel表达式收集数据&单元格映射&标题映射&模板文件的参数数据替换(第二版-增加深度读取和更新功能)
-
基于curl数据采集之单页面并行采集函数get_htmls的使用
-
使用Angular缓存父页面数据的方法
-
深入探讨:PHP使用数据库永久连接方式操作MySQL的是与非
-
PHP经典面试题:如何保证缓存与数据库的双写一致性?