首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >django 三种缓存模式的使用及注意点

django 三种缓存模式的使用及注意点

作者头像
用户1558882
发布2018-10-11 15:25:43
1.1K0
发布2018-10-11 15:25:43
举报
文章被收录于专栏:RgcRgc

Django 缓存模式的使用(主要针对RestFul设计模式的项目)

有三种模式:

  1. 全站使用缓存模式(整个项目每个接口都会使用缓存,缺点:所以接口都无法实时性获取数据)
  2. 单独视图缓存模式(单个接口使用缓存)
  3. 局部视图缓存模式

第一种:实现方式:

        必须在 settings中设置 缓存中间件

MIDDLEWARE = [
    'django.middleware.cache.UpdateCacheMiddleware',
        。。。其他中间件。。。
    'django.middleware.cache.FetchFromCacheMiddleware',
]

但是伴随的缺点就是 没有设置 缓存的接口默认都会有600秒的缓存,如下

无论清缓存还是换浏览器,因为缓存都是放在服务端的。

这就导致 那些不需要设置缓存,要求数据实时性较高的接口无法及时返回最新数据。

 所以:

如果需要使用 

from django.views.decorators.cache import cache_page, cache_control
from django.views.decorators.vary import vary_on_headers

    @cache_control,@vary_on_headers,@vary_on_cookie 

这些装饰器,就必须需要 缓存中间件,但是这样会导致其他接口都会有缓存600秒,需要慎重考虑使用

第二种

from django.views.decorators.cache import cache_page
@cache_page(10)

def cac(request):

    .......

这种方式只针对一个接口使用缓存(个人倾向于使用此方式)

第三种

涉及到模板的使用(具体没有研究过):

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-09-29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
消息队列 TDMQ
消息队列 TDMQ (Tencent Distributed Message Queue)是腾讯基于 Apache Pulsar 自研的一个云原生消息中间件系列,其中包含兼容Pulsar、RabbitMQ、RocketMQ 等协议的消息队列子产品,得益于其底层计算与存储分离的架构,TDMQ 具备良好的弹性伸缩以及故障恢复能力。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档