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'))
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值