Django缓存机制--rest_framework中节流源码使用的就是django提供的缓存api
https://www.jb51.net/article/124434.htm
- API 接口为:django.core.chache
存接口:cache.set(key, value, time_out)
取接口:cache.get(key)
有些时候,对整个经解析的页面进行缓存并不会给你带来太多好处,事实上可能会过犹不及。
比如说,也许你的站点所包含的一个视图依赖几个费时的查询,每隔一段时间结果就会发生变化。 在这种情况下,使用站点级缓存或者视图级缓存策略所提供的整页缓存并不是最理想的,因为你可能不会想对整个结果进行缓存(因为一些数据经常变化),但你仍然会想对很少变化的部分进行缓存。
针对这样的情况,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'
- 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),增减操作才是原子的。 然而,如果后端并不原生支持增减操作,也可以通过取值/更新两步操作来实现。
- 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
引入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 = [自己的访问频率控制类,]APIView 中dispatch方法封装了reqeust对象,initialize_request(request, *args, **kwargs)
初始化方法: self.initial(request, *args, **kwargs) 初始化认证
self.perform_authentication(request) #3.在这儿实现认证
self.check_permissions(request) #4.权限检查
 
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()) #抛出异常SimpleThrottle中:cache = default_cache 调用系统提供的cache-api接口
重写get_cache_key方法,返回自己将用来存储缓存的key
Django缓存机制--rest_framework中节流源码使用的就是django提供的缓存api的更多相关文章
- 【转载】Android异步消息处理机制详解及源码分析
PS一句:最终还是选择CSDN来整理发表这几年的知识点,该文章平行迁移到CSDN.因为CSDN也支持MarkDown语法了,牛逼啊! [工匠若水 http://blog.csdn.net/yanbob ...
- 【原】Spark中Master源码分析(二)
继续上一篇的内容.上一篇的内容为: Spark中Master源码分析(一) http://www.cnblogs.com/yourarebest/p/5312965.html 4.receive方法, ...
- 基于Redis缓存的Session共享(附源码)
基于Redis缓存的Session共享(附源码) 在上一篇文章中我们研究了Redis的安装及一些基本的缓存操作,今天我们就利用Redis缓存实现一个Session共享,基于.NET平台的Seesion ...
- 动态代理以及对应Spring中AOP源码分析
AOP(面向切面编程)在Spring中是被广泛应用的(例如日志,事务,权限等),而它的基本原理便是动态代理. 我们知道动态代理有两种:基于JDK的动态代理以及基于CGlib动态代理.以下是两种动态代理 ...
- Android应用AsyncTask处理机制详解及源码分析
1 背景 Android异步处理机制一直都是Android的一个核心,也是应用工程师面试的一个知识点.前面我们分析了Handler异步机制原理(不了解的可以阅读我的<Android异步消息处理机 ...
- 【转载】Android应用AsyncTask处理机制详解及源码分析
[工匠若水 http://blog.csdn.net/yanbober 转载烦请注明出处,尊重分享成果] 1 背景 Android异步处理机制一直都是Android的一个核心,也是应用工程师面试的一个 ...
- go 中 select 源码阅读
深入了解下 go 中的 select 前言 1.栗子一 2.栗子二 3.栗子三 看下源码实现 1.不存在 case 2.select 中仅存在一个 case 3.select 中存在两个 case,其 ...
- 【原】Spark中Client源码分析(二)
继续前一篇的内容.前一篇内容为: Spark中Client源码分析(一)http://www.cnblogs.com/yourarebest/p/5313006.html DriverClient中的 ...
- 【原】 Spark中Worker源码分析(二)
继续前一篇的内容.前一篇内容为: Spark中Worker源码分析(一)http://www.cnblogs.com/yourarebest/p/5300202.html 4.receive方法, r ...
随机推荐
- SpringBoot系列——Spring-Data-JPA
前言 jpa是ORM映射框架,更多详情,请戳:apring-data-jpa官网:http://spring.io/projects/spring-data-jpa,以及一篇优秀的博客:https:/ ...
- javascript小实例,阻止浏览器默认行为,真的能阻止吗?支持IE和标准浏览器的阻止默认行为的方法
看到这标题,是不是有点逆天的感觉,总感觉好狂拽炫酷,耳边隐隐约约传来一个声音:你这么叼,你咋不上天呢! ~~ 额,好吧! 话入正题,我为什么会提出这么一个问题呢? 阻止浏览器默认行为,真的能阻止吗?那 ...
- .Net语言 APP开发平台——Smobiler学习日志:获取或存储图像路径设置
ResourcePath属性 一.属性介绍 获取或设置图像存储路径,默认设置为“image”,表示的ResourcePath是在程序运行路径下的Image文件夹(bin\Debug\Image): 该 ...
- python-IO编程,文件读写
一.文件读写 1.打开文件 函数:open(name[. mode[. buffering]]) 参数: name:必须:文件的文件名(全路径或执行文件的相对路径.)) mode:可选:对文件的读写模 ...
- Java开发笔记(六十)匿名内部类的优势
前面依次介绍了简单接口和扩展接口,给出的范例都是自定义的接口代码,其实Java系统本身就自带了若干行为接口,为了更好地理解系统接口的详细用法,接下来还是从一个基础的例子出发,抽丝剥茧地逐步说明接口的几 ...
- Android Stuido xml使用app属性没有提示代码
解决方法: 打开file->invalidate Caches,之后build->rebuild project 2.重启Android Studio
- gulp前端自动化构建并上传oss
前言 前端自动化构建工具从最开始的grunt, gulp, fis等到现在比较流行的webpack可谓层出不穷,个人还是比较倾向于gulp,虽然有的时候会因为某个插件的配置问题头疼很久,但不可否认gu ...
- opencv3.2.0图像处理之高斯滤波GaussianBlur API函数
/*高斯滤波:GaussianBlur函数 函数原型: void GaussianBlur( InputArray src, OutputArray dst, Size ksize, double s ...
- DevOps 工程师实际上是做什么的
DevOps 工程师实际上是做什么的? 我们之前已经讨论过许多关于DevOps和DevOps世界的最新趋势了.但是DevOps工程师到底是做什么的? DevOps工程师以最纯粹的方式弥合了软件开发和运 ...
- 在AndroidStudio上使用AddressSanitizer
在AndroidStudio上使用AddressSanitizer AddressSanitizer是Google主导的一个开源内存问题检测工具.现在也开始支持Android平台,且受Google推荐 ...