一、配置缓存

https://www.jb51.net/article/124434.htm

二、缓存全站、页面、局部
三、自我控制的简单缓存API
  • API 接口为:django.core.chache

    存接口:cache.set(key, value, time_out)

    取接口:cache.get(key)

django中的低层次缓存API

有些时候,对整个经解析的页面进行缓存并不会给你带来太多好处,事实上可能会过犹不及。

比如说,也许你的站点所包含的一个视图依赖几个费时的查询,每隔一段时间结果就会发生变化。 在这种情况下,使用站点级缓存或者视图级缓存策略所提供的整页缓存并不是最理想的,因为你可能不会想对整个结果进行缓存(因为一些数据经常变化),但你仍然会想对很少变化的部分进行缓存。

针对这样的情况,Django提供了简单低级的缓存API。 你可以通过这个API,以任何你需要的粒度来缓存对象。 你可以对所有能够安全进行 pickle 处理的 Python 对象进行缓存: 字符串、字典和模型对象列表等等。 (查阅 Python 文档可以了解到更多关于 pickling 的信息。)

缓存模块django.core.cache拥有一个自动依据CACHE_BACKEND设置创建的django.core.cache对象。

使用缓存须知:默认调用settings 中的缓存配置

如果取的key不存在默认返回None

cache.get() 接受缺省参数:cache.get('my_key', 'has expired')

不存在将返回:'has expired'

自动删除没有设置超时时间、或者没超时的key
  • cache.delete(key)

     

    可以用 cache.delete() 显式地删除关键字:

     

    cache.delete('a')

也可以使用incr()或者decr()来增加或者减少已经存在的键值。 默认情况下,增加或减少的值是1。可以用参数来制定其他值。 如果尝试增减不存在的键值会抛出ValueError。

>>> cache.set('num', 1)
>>> cache.incr('num')
2
>>> cache.incr('num', 10)
12
>>> cache.decr('num')
11
>>> cache.decr('num', 5)
  • 注意:

     

    incr()/decr()方法不是原子操作。 在支持原子增减的缓存后端上(最著名的是memcached),增减操作才是原子的。 然而,如果后端并不原生支持增减操作,也可以通过取值/更新两步操作来实现。

 

3.2 rest_framework 源码解析
  • rest_framework中节流源码使用的就是django提供的缓存api
    def dispatch(self, request, *args, **kwargs):
...
self.args = args
self.kwargs = kwargs
############################################################## request = self.initialize_request(request, *args, **kwargs) # 1.封装request #封装后的request对象
#return Request(
# request,
# parsers=self.get_parsers(),
# authenticators=self.get_authenticators(), #获取认证对象
# negotiator=self.get_content_negotiator(),
# parser_context=parser_context
#) #############################################################
self.request = request
self.headers = self.default_response_headers # deprecate? try:
############################################################## self.initial(request, *args, **kwargs) #2 初始化认证 ##############################################################
...
except Exception as exc:
...
return self.response
  • 再看#2 self.initial(request, *args, **kwargs) 初始化各种认证的过程
    def initial(self, request, *args, **kwargs):
..... # Ensure that the incoming request is permitted self.perform_authentication(request) #3.在这儿实现认证 self.check_permissions(request) #4.权限检查 self.check_throttles(request) #5.访问频率控制
  • 重点看#5处,里面循化认证了频率控制:这儿就不贴出#5中的源码了

    直接将循环的类中去查看:from rest_framework.throttling import SimpleRateThrottle
class SimpleRateThrottle(BaseThrottle):
...
#实际是:from django.core.cache import cache as default_cache
cache = default_cache #可以看到这儿就是调用django提供的缓存api
...
scope = None #这儿是配置频率,可以到配置文件中去配置,也可以继承类重写:如3/m
... def get_cache_key(self, request, view):
"""
必须重写该方法,将缓存的 key返回:常用用户名、IP等做访问频率的控制
如:
return request.META.remote_addr() 或者 用户名
"""
raise NotImplementedError('.get_cache_key() must be overridden') def get_rate(self):
#从配置文件中拿出访问频率
... def parse_rate(self, rate):
#解析配置文件中的访问频率文本
... def allow_request(self, request, view):
#访问频率的控制,认证
... if self.rate is None:
return True self.key = self.get_cache_key(request, view) #从我们重写的方法中拿到缓存key
if self.key is None:
return True self.history = self.cache.get(self.key, []) #从缓存中拿出用该key存的数据
self.now = self.timer() ...
return self.throttle_success() def throttle_success(self):
#认证成功,重新设置缓存
...
self.history.insert(0, self.now)
self.cache.set(self.key, self.history, self.duration) #重新设置缓存
return True

 

3.2.2 总结rest_framework中的频率控制流程,及cache的使用
  1. 引入rest_framework: from rest_framework import APIView

    APIView继承了Django中的View 也就是CBV中的View

     

    引入:SimpleThrottle:from rest_framework.throttling import SimpleThrottle

    自己的类继承SimpleThrottle:并重写 get_cache_key(self, request, view)方法,以及scope 访问频率

    如果全局使用就配置到settings.py中:DEFALUT_THROTTLE_CLASSES = [自己的访问频率控制类, ]

    如果局部:就在继承了APIView中的类:throttle_classes = [自己的访问频率控制类,]

  2. APIView 中dispatch方法封装了reqeust对象,initialize_request(request, *args, **kwargs)

    初始化方法: self.initial(request, *args, **kwargs) 初始化认证

     

    self.perform_authentication(request) #3.在这儿实现认证

     

    self.check_permissions(request) #4.权限检查

    &nbsp

    self.check_throttles(request) #5.访问频率控制

     

    def check_throttles(self, request):

    ...

    for throttle in self.get_throttles(): #循环认证我们自己的访问频率控制类

    ....if not throttle.allow_request(request, self): #调用里面的allow_request 方法

    ........self.throttled(request, throttle.wait()) #抛出异常

  3. SimpleThrottle中:cache = default_cache 调用系统提供的cache-api接口

    重写get_cache_key方法,返回自己将用来存储缓存的key

Django缓存机制--rest_framework中节流源码使用的就是django提供的缓存api的更多相关文章

  1. 【转载】Android异步消息处理机制详解及源码分析

    PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbob ...

  2. 【原】Spark中Master源码分析(二)

    继续上一篇的内容.上一篇的内容为: Spark中Master源码分析(一) http://www.cnblogs.com/yourarebest/p/5312965.html 4.receive方法, ...

  3. 基于Redis缓存的Session共享(附源码)

    基于Redis缓存的Session共享(附源码) 在上一篇文章中我们研究了Redis的安装及一些基本的缓存操作,今天我们就利用Redis缓存实现一个Session共享,基于.NET平台的Seesion ...

  4. 动态代理以及对应Spring中AOP源码分析

    AOP(面向切面编程)在Spring中是被广泛应用的(例如日志,事务,权限等),而它的基本原理便是动态代理. 我们知道动态代理有两种:基于JDK的动态代理以及基于CGlib动态代理.以下是两种动态代理 ...

  5. Android应用AsyncTask处理机制详解及源码分析

    1 背景 Android异步处理机制一直都是Android的一个核心,也是应用工程师面试的一个知识点.前面我们分析了Handler异步机制原理(不了解的可以阅读我的<Android异步消息处理机 ...

  6. 【转载】Android应用AsyncTask处理机制详解及源码分析

    [工匠若水 http://blog.csdn.net/yanbober 转载烦请注明出处,尊重分享成果] 1 背景 Android异步处理机制一直都是Android的一个核心,也是应用工程师面试的一个 ...

  7. go 中 select 源码阅读

    深入了解下 go 中的 select 前言 1.栗子一 2.栗子二 3.栗子三 看下源码实现 1.不存在 case 2.select 中仅存在一个 case 3.select 中存在两个 case,其 ...

  8. 【原】Spark中Client源码分析(二)

    继续前一篇的内容.前一篇内容为: Spark中Client源码分析(一)http://www.cnblogs.com/yourarebest/p/5313006.html DriverClient中的 ...

  9. 【原】 Spark中Worker源码分析(二)

    继续前一篇的内容.前一篇内容为: Spark中Worker源码分析(一)http://www.cnblogs.com/yourarebest/p/5300202.html 4.receive方法, r ...

随机推荐

  1. 【.NET Core项目实战-统一认证平台】第十三章 授权篇-如何强制有效令牌过期

    [.NET Core项目实战-统一认证平台]开篇及目录索引 上一篇我介绍了JWT的生成验证及流程内容,相信大家也对JWT非常熟悉了,今天将从一个小众的需求出发,介绍如何强制令牌过期的思路和实现过程. ...

  2. PhpStorm 运行出现502 Bad Gateway

    打开PhpStorm,菜单栏File --> Settings... 一.点开Languages & Frameworks 选PHP PHP language level:选PHP版本, ...

  3. 博弈论进阶之Multi-SG

    Multi-Nim 从最简单的Nim模型开始 它的定义是这样的 有\(n\)堆石子,两个人可以从任意一堆石子中拿任意多个石子(不能不拿)或把一堆数量不少于\(2\)石子分为两堆不为空的石子,没法拿的人 ...

  4. 将Dynamics 365中的用户及其角色、角色导出到Excel中

    关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复240或者20161204可方便获取本文,同时可以在第一间得到我发布的最新的博文信息,follow me!我的网站是 www.luoyong. ...

  5. 【图解】FlexGrid Explorer 全功能问世

    前言 在去年的时候,我们推出了FlexGrid Demo,包含了FlexGrid的常用功能,如分组.滚动.冻结.自定义单元格类型.搜索面板.表格过滤器.树形结构.合并单元等,目前我们又在里面添加很多了 ...

  6. LayoutInflater.inflate()方法两个参数和三个参数

    转载请标明出处:https://www.cnblogs.com/tangZH/p/7074853.html  很多人都用过LayoutInflater(布局填充器) 对于我来说通常使用下面两种:Lay ...

  7. 自定义Progress小控件

    progress各种各样的都有,自定义大多数也是简单的,根据业务需求来自己定义,记录一下,先上效果图 本来想找个第三方改改就上的,不过自己的业务需求有点不搭,一下子没找到合适的,也没这么多时间去找了, ...

  8. Actor模型浅析 一致性和隔离性

    一.Actor模型介绍 在单核 CPU 发展已经达到一个瓶颈的今天,要增加硬件的速度更多的是增加 CPU 核的数目.而针对这种情况,要使我们的程序运行效率提高,那么也应该从并发方面入手.传统的多线程方 ...

  9. sql order by和case THEN 并用

    今天在工作中遇到一个多表查询,并且按精准度匹配排序的一个需求,费了我好大劲在此和大家分享一些心得 开始我是想根据他的搜索字段的长度来排序,但是遇到图二的这种结果就不好排序了 order by abs( ...

  10. Java - String 的字面量、常量池、构造函数和intern()函数

    一.内存中的 String 对象 Java 的堆和栈 对于基本数据类型变量和对象的引用,也就是局部变量表属于栈内存: 而通过 new 关键字和 constructor 创建的对象存放在堆内存: 直接的 ...