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() 
  • 相关阅读:
    Spring中的AOP(五)——定义切入点和切入点指示符
    Java获取URL对应的资源
    最简单的视频网站(JavaEE+FFmpeg)
    Android 为应用添加数字角标
    ViewTreeObserver简介
    Android中pendingIntent的深入理解
    在Windows的CMD中如何设置支持UTF8编码?
    android中角标的实现
    ANDROID SHAPE画圆形背景_ANDROID实现角标布局
    Android 学习之 开源项目PullToRefresh的使用
  • 原文地址:https://www.cnblogs.com/alexzhang92/p/9529708.html
Copyright © 2011-2022 走看看