一、官方文档:
https://docs.djangoproject.com/en/dev/topics/cache/
二、配置
1、开发调试配置(此模式为开发调试使用,实际上不执行任何操作)
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.dummy.DummyCache',
'TIMEOUT': 300,
'OPTIONS': {
'MAX_ENTRIES': 300,
'CULL_FREQUENCY': 2,
},
}
}
2、数据库
(1)配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
'LOCATION': 'my_cache_table',
'TIMEOUT': 300,
'OPTIONS': {
'MAX_ENTRIES': 300,
'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',
'TIMEOUT': 300,
'OPTIONS': {
'MAX_ENTRIES': 300,
'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'))
|