一、官方文档:
https://docs.djangoproject.com/en/dev/topics/cache/
二、配置
1、开发调试配置(此模式为开发调试使用,实际上不执行任何操作)
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.dummy.DummyCache', # 缓存后台使用的引擎
'TIMEOUT': 300, # 缓存超时时间(默认300秒,None表示永不过期,0表示立即过期)
'OPTIONS': {
'MAX_ENTRIES': 300, # 最大缓存记录的数量(默认300)
'CULL_FREQUENCY': 2, # 缓存到达最大个数之后,剔除缓存个数的比例,即:1/CULL_FREQUENCY(默认3)
},
}
}
2、数据库
(1)配置
CACHES = {
'default': {
# 数据库缓存
'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
'LOCATION': 'my_cache_table',
# 缓存保存时间,单位:秒
'TIMEOUT': 300,
'OPTIONS': {
# 缓存最大条数
'MAX_ENTRIES': 300,
# 达到最大条数时,删除 1/n的缓存数据
'CULL_FREQUENCY': 2
}
}
}
(2)数据库配置需要预先执行python manage.py createcachetable
来创建数据库,在views中加入装饰器@cache_page,访问时即可看到数据库生成的内容。
@cache_page括号内为缓存的秒数。
以下为数据库中的内容。
3、内存
CACHES = {
'default': {
# 指定缓存使用的引擎
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
# 写在内存中的变量的唯一值
'LOCATION': 'unique-snowflake',
# 缓存超时时间(默认为300秒,None表示永不过期)
'TIMEOUT': 300,
'OPTIONS': {
# 最大缓存记录的数量(默认300)
'MAX_ENTRIES': 300,
# 缓存到达最大个数之后,剔除缓存个数的比例,即:1/n(默认3)
'CULL_FREQUENCY': 2,
}
}
}
4、文件
(1)配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
# 这里给出的是路径,很多时候是在项目根目录创建个文件夹
'LOCATION': os.path.join(BASE_DIR, 'cache'),
}
}
(2)再次访问对应地址可以看到,创建了一个文件夹存储数据。
5、Memcache
(1)配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache',
'LOCATION': ['127.0.0.1:11211']
}
}
(2)这样使用的话,需要安装Memcached以及相应的支持库python-memcached或pylibmc。
6、Redis
(1)配置
CACHES = {
"default": {
"BACKEND": "django_redis.cache.RedisCache",
"LOCATION": "redis://192.168.10.202:6379",
"OPTIONS": {
"CLIENT_CLASS": "django_redis.client.DefaultClient",
"CONNECTION_POOL_KWARGS": {
"max_connections": 100}
}
}
}
(2)使用时,需要安装redis相关依赖pip install django-redis
,然后在使用的时候,也需要自己创建对象。
def test_cache3(request):
# 引入依赖
from django_redis import get_redis_connection
t = time.time()
t = time.time()
# 创建对象
cache = get_redis_connection("default")
# 加入缓存(最后一个参数为秒数,不填则表示不过期)
cache.set('time', t, 200)
return HttpResponse(cache.get('time'))