Django缓存配置


一、官方文档:

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'))

猜你喜欢

转载自blog.csdn.net/qq_40579464/article/details/123870324