zoukankan      html  css  js  c++  java
  • django之设置缓存

    缓存

    一句话总结:缓存可以对view、模板、数据进行缓存可以设置缓存在不同的地方(本地内存、redis、系统文档)可以为服务器节省性能、减少用户等待时间。

    • 对于中等流量的网站来说,尽可能地减少开销是必要的。缓存数据就是为了保存那些需要很多计算资源的结果,这样的话就不必在下次重复消耗计算资源
    • Django自带了一个健壮的缓存系统来保存动态页面,避免对于每次请求都重新计算
    • Django提供了不同级别的缓存粒度:可以缓存特定视图的输出可以仅仅缓存那些很难生产出来的部分或者可以缓存整个网站

    设置缓存

    • 通过设置决定把数据缓存在哪里,是数据库中文件系统还是在内存、或者是redis
    • 通过setting文件的CACHES配置来实现
    • 参数TIMEOUT:缓存的默认过期时间,以秒为单位,这个参数默认是300秒,即5分钟;设置TIMEOUT为None表示永远不会过期,值设置成0造成缓存立即失效
    CACHES={
        'default': {
            'BACKEND': 'django.core.cache.backends.locmem.LocMemCache', #缓存到本地内存中
            'TIMEOUT': 60,
        }
    }
    • 可以将cache存到redis中默认采用1数据库,需要安装包并配置如下: 
    安装包:pip install django-redis-cache
    
    CACHES 
        "default": {
            "BACKEND": "redis_cache.cache.RedisCache",  #缓存到redis中
            "LOCATION": "localhost:6379",
            'TIMEOUT': 60,
        },
    } 
    • 可以连接redis查看存的数据 
    连接:redis-cli
    切换数据库:select 1
    查看键:keys *
    查看值:get 键

    单个view缓存

    • django.views.decorators.cache定义了cache_page装饰器,用于对视图的输出进行缓存
    • 示例代码如下:
    from django.views.decorators.cache import cache_page
    
    @cache_page(60 * 15)
    def index(request):
        return HttpResponse('hello1')
        #return HttpResponse('hello2')
    • cache_page接受一个参数:timeout,秒为单位,上例中缓存了15分钟
    • 视图缓存与URL无关,如果多个URL指向同一视图,每个URL将会分别缓存
    • 模板片断缓存

    • 使用cache模板标签来缓存模板的一个片段
    • 需要两个参数:
      • 缓存时间,以秒为单位
      • 给缓存片段起的名称
    • 示例代码如下:
    {% load cache %}
    {% cache 500 hello %}
    hello1
    <!--hello2-->
    {% endcache %}

    底层的缓存API

    from django.core.cache import cache
    
    设置:cache.set(键,值,有效时间)
    获取:cache.get(键)
    删除:cache.delete(键)
    清空:cache.clear() 
  • 相关阅读:
    flex学习网站地址
    ASP.NET 开发人员应该知道的8个网站
    登入页面添加图片有重复页面出现怎么办
    一行代码是有两个??
    c# 枚举基础有[flags]和没有的的区别
    c#中[Flags] 枚举类型定义问题_百度知道
    写出一条Sql语句:取出表A中第31到第40记录(SQLServer,以自动增长的ID作为主键,注意:ID可能不是连续的。
    Margin和Padding之间的区别
    对于top.ascx里面可以不可以放置css的文件进行一个讲解
    设计模式之--适配器模式(Adapter)
  • 原文地址:https://www.cnblogs.com/alexzhang92/p/9529708.html
Copyright © 2011-2022 走看看