Django中提供的6种缓存方式详解


Posted in Python onAugust 05, 2019

前言

由于Django是动态网站,所有每次请求均会去数据进行相应的操作,当程序访问量大时,耗时必然会更加明显,最简单解决方式是使用:缓存,缓存将一个某个views的返回值保存至内存或者memcache中,5分钟内再有人来访问时,则不再去执行view中的操作,而是直接从内存或者Redis中之前缓存的内容拿到,并返回。

Django中提供了6种缓存方式:

  • 开发调试
  • 内存
  • 文件
  • 数据库
  • Memcache缓存(python-memcached模块)
  • Memcache缓存(pylibmc模块)

1、配置

a、开发调试

# 此为开始调试用,实际内部不做任何操作
  # 配置:
    CACHES = {
      'default': {
        'BACKEND': 'django.core.cache.backends.dummy.DummyCache',   # 引擎
        'TIMEOUT': 300,                        # 缓存超时时间(默认300,None表示永不过期,0表示立即过期)
        'OPTIONS':{
          'MAX_ENTRIES': 300,                    # 最大缓存个数(默认300)
          'CULL_FREQUENCY': 3,                   # 缓存到达最大个数之后,剔除缓存个数的比例,即:1/CULL_FREQUENCY(默认3)
        },
        'KEY_PREFIX': '',                       # 缓存key的前缀(默认空)
        'VERSION': 1,                         # 缓存key的版本(默认1)
        'KEY_FUNCTION' 函数名                     # 生成key的函数(默认函数会生成为:【前缀:版本:key】)
      }
    }
  # 自定义key
  def default_key_func(key, key_prefix, version):
    """
    Default function to generate keys.
    Constructs the key used by all other methods. By default it prepends
    the `key_prefix'. KEY_FUNCTION can be used to specify an alternate
    function with custom key making behavior.
    """
    return '%s:%s:%s' % (key_prefix, version, key)

  def get_key_func(key_func):
    """
    Function to decide which key function to use.
    Defaults to ``default_key_func``.
    """
    if key_func is not None:
      if callable(key_func):
        return key_func
      else:
        return import_string(key_func)
    return default_key_func

b、内存

# 此缓存将内容保存至内存的变量中
  # 配置:
    CACHES = {
      'default': {
        'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
        'LOCATION': 'unique-snowflake',  #unique-snowflake是起的一个变量名
      }
    }
  # 注:其他配置同开发调试版本

c、文件

# 此缓存将内容保存至文件
  # 配置:
    CACHES = {
      'default': {
        'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
        'LOCATION': '/var/tmp/django_cache',
      }
    }
  # 注:其他配置同开发调试版本

d、数据库

# 此缓存将内容保存至数据库
  # 配置:
    CACHES = {
      'default': {
        'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
        'LOCATION': 'my_cache_table', # 数据库表
      }
    }
  # 注:执行创建表命令 python manage.py createcachetable

e、Memcache缓存(python-memcached模块)

# 此缓存使用python-memcached模块连接memcache
  CACHES = {
    'default': {
      'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
      'LOCATION': '127.0.0.1:11211',
    }
  }
  CACHES = {
    'default': {
      'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
      'LOCATION': 'unix:/tmp/memcached.sock',
    }
  }  
  CACHES = {
    'default': {
      'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
      'LOCATION': [
        '172.19.26.240:11211',
        '172.19.26.242:11211',
      ]
    }
  }

f、Memcache缓存(pylibmc模块)

# 此缓存使用pylibmc模块连接memcache  
  CACHES = {
    'default': {
      'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
      'LOCATION': '127.0.0.1:11211',
    }
  }
  CACHES = {
    'default': {
      'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
      'LOCATION': '/tmp/memcached.sock',
    }
  }  
  CACHES = {
    'default': {
      'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache',
      'LOCATION': [
        '172.19.26.240:11211',
        '172.19.26.242:11211',
      ]
    }
  }

g. Redis缓存(依赖:pip3 install django-redis)

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": 100}
      # "PASSWORD": "密码",
    }
  }
}

在views.py中的配置

from django_redis import get_redis_connection
conn = get_redis_connection("default")

2、应用

a. 全站使用

使用中间件,经过一系列的认证等操作,如果内容在缓存中存在,则使用FetchFromCacheMiddleware获取内容并返回给用户,当返回给用户之前,判断缓存中是否已经存在,如果不存在则UpdateCacheMiddleware会将缓存保存至缓存,从而实现全站缓存

MIDDLEWARE = [
    'django.middleware.cache.UpdateCacheMiddleware',
    # 其他中间件...
    'django.middleware.cache.FetchFromCacheMiddleware',
  ]
  CACHE_MIDDLEWARE_ALIAS = ""
  CACHE_MIDDLEWARE_SECONDS = ""
  CACHE_MIDDLEWARE_KEY_PREFIX = ""

b. 单独视图缓存

方式一:

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)),
    ]

c、局部视图使用

a. 引入TemplateTag

{% load cache %}

b. 使用缓存

{% cache 5000 缓存key %}
      缓存内容
    {% endcache %}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在Python中进行自动化单元测试的教程
Apr 15 Python
python+Django+apache的配置方法详解
Jun 01 Python
linux平台使用Python制作BT种子并获取BT种子信息的方法
Jan 20 Python
Python 实现购物商城,含有用户入口和商家入口的示例
Sep 15 Python
Python实现小数转化为百分数的格式化输出方法示例
Sep 20 Python
Python中最大最小赋值小技巧(分享)
Dec 23 Python
TensorFlow的权值更新方法
Jun 14 Python
基于Python实现定时自动给微信好友发送天气预报
Oct 25 Python
Python实现对字典分别按键(key)和值(value)进行排序的方法分析
Dec 19 Python
在macOS上搭建python环境的实现方法
Aug 13 Python
使用Python项目生成所有依赖包的清单方式
Jul 13 Python
python 基于opencv 实现一个鼠标绘图小程序
Dec 11 Python
python修改字典键(key)的方法
Aug 05 #Python
python中使用while循环的实例
Aug 05 #Python
Python3 列表,数组,矩阵的相互转换的方法示例
Aug 05 #Python
Python中print函数简单使用总结
Aug 05 #Python
Numpy数组array和矩阵matrix转换方法
Aug 05 #Python
python标记语句块使用方法总结
Aug 05 #Python
python Django里CSRF 对应策略详解
Aug 05 #Python
You might like
php实现根据url自动生成缩略图的方法
2014/09/23 PHP
Jquery中显示隐藏的实现代码分析
2011/07/26 Javascript
js 连接数据库如何操作数据库中的数据
2012/11/23 Javascript
可以用鼠标拖动的DIV实现思路及代码
2013/10/21 Javascript
javascript的document.referrer浏览器支持、失效情况总结
2014/07/18 Javascript
JavaScript中的操作符==与===介绍
2014/12/31 Javascript
JavaScript的Date()方法使用详解
2015/06/09 Javascript
JS实现的仿淘宝交易倒计时效果
2015/11/27 Javascript
Jquery attr()方法 属性赋值和属性获取详解
2016/04/15 Javascript
jQuery实现定时隐藏对话框的方法分析
2018/02/12 jQuery
解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题
2018/08/20 Javascript
Bootstrap的aria-label和aria-labelledby属性实例详解
2018/11/02 Javascript
jQuery实现带3D切割效果的轮播图功能示例【附源码下载】
2019/04/04 jQuery
vue路由守卫+登录态管理实例分析
2019/05/21 Javascript
简谈创建React Component的几种方式
2019/06/15 Javascript
修改NPM全局模式的默认安装路径的方法
2020/12/15 Javascript
[47:03]Ti4第二日主赛事败者组 LGD vs iG 2
2014/07/21 DOTA
Python中使用logging模块打印log日志详解
2015/04/05 Python
Python插件virtualenv搭建虚拟环境
2017/11/20 Python
Python中的pygal安装和绘制直方图代码分享
2017/12/08 Python
关于python2 csv写入空白行的问题
2018/06/22 Python
python Elasticsearch索引建立和数据的上传详解
2019/08/04 Python
python实现PID算法及测试的例子
2019/08/08 Python
Python pandas库中的isnull()详解
2019/12/26 Python
TensorFlow实现保存训练模型为pd文件并恢复
2020/02/06 Python
Django操作session 的方法
2020/03/09 Python
Python 线性回归分析以及评价指标详解
2020/04/02 Python
python 调用Google翻译接口的方法
2020/12/09 Python
HTML5新增属性data-*和js/jquery之间的交互及注意事项
2017/08/08 HTML / CSS
全球游戏Keys和卡片市场:GamesDeal
2018/03/28 全球购物
拉飞逸官网:Lafayette 148 New York
2020/07/15 全球购物
经理管理专业自荐信范文
2013/12/31 职场文书
决定成败的关键——创业计划书
2014/01/24 职场文书
料理师求职信
2014/01/30 职场文书
Python数组变形的几种实现方法
2022/05/30 Python
Linux中各个目录的作用与内容
2022/06/28 Servers