Django框架深入了解_05 (Django中的缓存、Django解决跨域流程(非简单请求,简单请求)、自动生成接口文档)(一)
閱讀目錄
-
一、Django中的緩存:
前戲:
Django中的幾種緩存方式:
Django中的緩存應(yīng)用: -
二、跨域:
跨域知識(shí)介紹:
CORS請(qǐng)求分類(簡單請(qǐng)求和非簡單請(qǐng)求)
示例: -
三、自動(dòng)生成接口文檔
一、Django中的緩存:
前戲:
在動(dòng)態(tài)網(wǎng)站中,用戶所有的請(qǐng)求,服務(wù)器都會(huì)去數(shù)據(jù)庫中進(jìn)行相應(yīng)的增,刪,查,改,渲染模板,執(zhí)行業(yè)務(wù)邏輯,最后生成用戶看到的頁面.
當(dāng)一個(gè)網(wǎng)站的用戶訪問量很大的時(shí)候,每一次的的后臺(tái)操作,都會(huì)消耗很多的服務(wù)端資源,所以必須使用緩存來減輕后端服務(wù)器的壓力.
緩存是將一些常用的數(shù)據(jù)保存內(nèi)存或者memcache中,在一定的時(shí)間內(nèi)有人來訪問這些數(shù)據(jù)時(shí),則不再去執(zhí)行數(shù)據(jù)庫及渲染等操作,而是直接從內(nèi)存或memcache的緩存中去取得數(shù)據(jù),然后返回給用戶.
Django中的幾種緩存方式:
-開發(fā)調(diào)試階段:沒有緩存
-緩存到內(nèi)存中:settings.py文件配置
-緩存到數(shù)據(jù)庫:settings.py文件配置
CACHES = {'default': {'BACKEND': 'django.core.cache.backends.db.DatabaseCache', # 指定緩存使用的引擎'LOCATION': 'cache_table', # 數(shù)據(jù)庫表 'OPTIONS':{'MAX_ENTRIES': 300, # 最大緩存記錄的數(shù)量(默認(rèn)300)'CULL_FREQUENCY': 3, # 緩存到達(dá)最大個(gè)數(shù)之后,剔除緩存?zhèn)€數(shù)的比例,即:1/CULL_FREQUENCY(默認(rèn)3)} } }-緩存到文件:settings.py文件配置
CACHES = {'default': {'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache', #指定緩存使用的引擎'LOCATION': '/var/tmp/django_cache', #指定緩存的路徑'TIMEOUT':300, #緩存超時(shí)時(shí)間(默認(rèn)為300秒,None表示永不過期)'OPTIONS':{'MAX_ENTRIES': 300, # 最大緩存記錄的數(shù)量(默認(rèn)300)'CULL_FREQUENCY': 3, # 緩存到達(dá)最大個(gè)數(shù)之后,剔除緩存?zhèn)€數(shù)的比例,即:1/CULL_FREQUENCY(默認(rèn)3)}} }注意,創(chuàng)建緩存的數(shù)據(jù)庫表使用的語句:
python manage.py createcachetable-Memcache緩存(使用python-memcached模塊連接memcache)
Memcached是Django原生支持的緩存系統(tǒng).要使用Memcached,需要下載Memcached的支持庫python-memcached或pylibmc.
settings.py文件配置
CACHES = {'default': {'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', # 指定緩存使用的引擎'LOCATION': '192.168.10.100:11211', # 指定Memcache緩存服務(wù)器的IP地址和端口'OPTIONS':{'MAX_ENTRIES': 300, # 最大緩存記錄的數(shù)量(默認(rèn)300)'CULL_FREQUENCY': 3, # 緩存到達(dá)最大個(gè)數(shù)之后,剔除緩存?zhèn)€數(shù)的比例,即:1/CULL_FREQUENCY(默認(rèn)3)}} } 復(fù)制代碼 LOCATION也可以配置成如下:LOCATION也可以配置成如下:
'LOCATION': 'unix:/tmp/memcached.sock', # 指定局域網(wǎng)內(nèi)的主機(jī)名加socket套接字為Memcache緩存服務(wù)器 'LOCATION': [ # 指定一臺(tái)或多臺(tái)其他主機(jī)ip地址加端口為Memcache緩存服務(wù)器'192.168.10.100:11211','192.168.10.101:11211','192.168.10.102:11211', ]-Memcache緩存(使用pylibmc模塊連接memcache)
settings.py文件配置CACHES = {'default': {'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache', # 指定緩存使用的引擎'LOCATION':'192.168.10.100:11211', # 指定本機(jī)的11211端口為Memcache緩存服務(wù)器'OPTIONS':{'MAX_ENTRIES': 300, # 最大緩存記錄的數(shù)量(默認(rèn)300)'CULL_FREQUENCY': 3, # 緩存到達(dá)最大個(gè)數(shù)之后,剔除緩存?zhèn)€數(shù)的比例,即:1/CULL_FREQUENCY(默認(rèn)3)}, }}LOCATION也可以配置成如下:
'LOCATION': '/tmp/memcached.sock', # 指定某個(gè)路徑為緩存目錄 'LOCATION': [ # 分布式緩存,在多臺(tái)服務(wù)器上運(yùn)行Memcached進(jìn)程,程序會(huì)把多臺(tái)服務(wù)器當(dāng)作一個(gè)單獨(dú)的緩存,而不會(huì)在每臺(tái)服務(wù)器上復(fù)制緩存值'192.168.10.100:11211','192.168.10.101:11211','192.168.10.102:11211', ]Memcached是基于內(nèi)存的緩存,數(shù)據(jù)存儲(chǔ)在內(nèi)存中.所以如果服務(wù)器死機(jī)的話,數(shù)據(jù)就會(huì)丟失,所以Memcached一般與其他緩存配合使用
Django中的緩存應(yīng)用:
Django提供了不同粒度的緩存,可以緩存某個(gè)頁面,可以只緩存一個(gè)頁面的某個(gè)部分,甚至可以緩存整個(gè)網(wǎng)站.
緩存粒度:
單頁面緩存:
在視圖函數(shù)上加一個(gè)裝飾器(基于FBV)
如果是CBV的化實(shí)現(xiàn)方法為:
from django.views.decorators.cache import cache_page from django.utils.decorators import method_decorator @method_decorator(cache_page(5), name='dispatch') class ShowTime(APIView):def get(self, request):ctime = time.strftime('%Y-%m-%d %H:%M:%S')return render(request, 'show_time.html', {'ctime': ctime})
上面的例子是基于內(nèi)存的緩存配置,基于文件的緩存該怎么配置呢??
更改settings.py的配置
CACHES = {'default': {'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache', # 指定緩存使用的引擎'LOCATION': 'E:\django_cache', # 指定緩存的路徑'TIMEOUT': 300, # 緩存超時(shí)時(shí)間(默認(rèn)為300秒,None表示永不過期)'OPTIONS': {'MAX_ENTRIES': 300, # 最大緩存記錄的數(shù)量(默認(rèn)300)'CULL_FREQUENCY': 3, # 緩存到達(dá)最大個(gè)數(shù)之后,剔除緩存?zhèn)€數(shù)的比例,即:1/CULL_FREQUENCY(默認(rèn)3)}} }然后再次刷新瀏覽器,可以看到在剛才配置的目錄下生成的緩存文件
通過實(shí)驗(yàn)可以知道,Django會(huì)以自己的形式把緩存文件保存在配置文件中指定的目錄中.
- 全站使用緩存:
使用方法:在Django中間件最上面和最下面添加2個(gè)中間件:
# 緩存全站: # 在 MIDDLEWARE_CLASSES 中加入 “update” 和 “fetch” 中間件 # “update” 必須配置在第一個(gè) # “fetch” 必須配置在最后一個(gè)'django.middleware.cache.UpdateCacheMiddleware', # process_response方法中更新緩存。。。。 'django.middleware.cache.FetchFromCacheMiddleware' # process_request方法中獲取緩存同時(shí)在settings.py中再添加一個(gè)參數(shù):
CACHE_MIDDLEWARE_SECONDS=10 # 緩存時(shí)間用戶的請(qǐng)求通過中間件,經(jīng)過一系列的認(rèn)證等操作,如果請(qǐng)求的內(nèi)容在緩存中存在,則使用FetchFromCacheMiddleware獲取內(nèi)容并返回給用戶,
(如果一開始還沒有建立緩存,如果所有校驗(yàn)通過后,拿到數(shù)據(jù),在請(qǐng)求走的時(shí)候,最上面中間件中要進(jìn)行數(shù)據(jù)的緩存)
也就是請(qǐng)求走的時(shí)候,在最上面的中間件中進(jìn)行判斷緩存是否已經(jīng)存在,如果不存在,就使用UpdateCacheMiddleware對(duì)該數(shù)據(jù)進(jìn)行緩存。
局部使用緩存:
# 視圖無需設(shè)置def show_time(request):ctime = time.strftime('%Y-%m-%d %H:%M:%S')return render(request, 'show_time.html', {'ctime': ctime}) # 在頁面文件中進(jìn)行渲染 <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>緩存測試</title> </head> <body> <p>{{ ctime }}</p> {% load cache %} {% cache 5 'test' %}{{ ctime }} {% endcache %} </body> </html>tips:高級(jí)用法
-前后端分離項(xiàng)目
-設(shè)置值和取值:
總結(jié)
以上是生活随笔為你收集整理的Django框架深入了解_05 (Django中的缓存、Django解决跨域流程(非简单请求,简单请求)、自动生成接口文档)(一)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Django框架之DRF 认证组件源码分
- 下一篇: Django框架深入了解_05 (Dja