Django框架(二十八)—— Django快取機制
阿新 • • 發佈:2018-12-24
目錄
Django快取機制
一、什麼是快取
動態網站中,使用者請求都要去伺服器的資料庫中增刪改查,會消耗很大的資源,因此,使用快取在減輕伺服器的壓力。
快取是將一些常用的資料儲存記憶體或者memcache中,在一定的時間內有人來訪問這些資料時,則不再去執行資料庫及渲染等操作,而是直接從記憶體或memcache的快取中去取得資料,然後返回給使用者。
二、Django的6中快取方式及配置(只需要改配置檔案)
1、開發除錯快取(此模式為開發除錯使用,實際上不執行任何操作)
settings.py檔案中配置
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.dummy.DummyCache', # 快取後臺使用的引擎 'TIMEOUT': 300, # 快取超時時間(預設300秒,None表示永不過期,0表示立即過期) 'OPTIONS':{ 'MAX_ENTRIES': 300, # 最大快取記錄的數量(預設300) 'CULL_FREQUENCY': 3, # 快取到達最大個數之後,剔除快取個數的比例,即:1/CULL_FREQUENCY(預設3) }, } }
2、記憶體快取(將快取內容儲存至記憶體區域中)
settings.py檔案中配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache', # 指定快取使用的引擎
'LOCATION': 'unique-snowflake', # 寫在記憶體中的變數的唯一值
'TIMEOUT':300, # 快取超時時間(預設為300秒,None表示永不過期)
'OPTIONS':{
'MAX_ENTRIES': 300, # 最大快取記錄的數量(預設300)
'CULL_FREQUENCY': 3, # 快取到達最大個數之後,剔除快取個數的比例,即:1/CULL_FREQUENCY(預設3)
}
}
}
3、檔案快取(將快取內容儲存至檔案區域中)
settings.py檔案中配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache', #指定快取使用的引擎
'LOCATION': 'D:\test\cache', #指定快取的路徑
'TIMEOUT':300, #快取超時時間(預設為300秒,None表示永不過期)
'OPTIONS':{
'MAX_ENTRIES': 300, # 最大快取記錄的數量(預設300)
'CULL_FREQUENCY': 3, # 快取到達最大個數之後,剔除快取個數的比例,即:1/CULL_FREQUENCY(預設3)
}
}
}
4、資料庫快取(將快取內容儲存至資料庫區域中)
settings.py檔案中配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.db.DatabaseCache', # 指定快取使用的引擎
'LOCATION': 'cache_table', # 資料庫表
'OPTIONS':{
'MAX_ENTRIES': 300, # 最大快取記錄的數量(預設300)
'CULL_FREQUENCY': 3, # 快取到達最大個數之後,剔除快取個數的比例,即:1/CULL_FREQUENCY(預設3)
}
}
}
5、Memcache快取(使用python-memcached模組)
- Memcached是Django原生支援的快取系統.要使用Memcached,需要下載Memcached的支援庫python-memcached或pylibmc
settings.py檔案中配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', # 指定快取使用的引擎
'LOCATION': '192.168.10.100:8888', # 指定Memcache快取伺服器的IP地址和埠
'OPTIONS':{
'MAX_ENTRIES': 300, # 最大快取記錄的數量(預設300)
'CULL_FREQUENCY': 3, # 快取到達最大個數之後,剔除快取個數的比例,即:1/CULL_FREQUENCY(預設3)
}
}
}
LOCATION也可以如下配置:
'LOCATION': 'unix:/tmp/memcached.sock', # 指定區域網內的主機名加socket套接字為Memcache快取伺服器
'LOCATION': [ # 指定一臺或多臺其他主機ip地址加埠為Memcache快取伺服器
'192.168.10.100:11211',
'192.168.10.101:11211',
'192.168.10.102:11211',
]
6、Memcache快取(使用pylibmc模組)
settings.py檔案中配置
CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.memcached.PyLibMCCache', # 指定快取使用的引擎
'LOCATION':'192.168.10.100:11211', # 指定本機的11211埠為Memcache快取伺服器
'OPTIONS':{
'MAX_ENTRIES': 300, # 最大快取記錄的數量(預設300)
'CULL_FREQUENCY': 3, # 快取到達最大個數之後,剔除快取個數的比例,即:1/CULL_FREQUENCY(預設3)
},
}
}
LOCATION也可以如下配置:
'LOCATION': 'unix:/tmp/memcached.sock', # 指定區域網內的主機名加socket套接字為Memcache快取伺服器
'LOCATION': [ # 指定一臺或多臺其他主機ip地址加埠為Memcache快取伺服器
'192.168.10.100:11211',
'192.168.10.101:11211',
'192.168.10.102:11211',
]
三、快取的應用
1、單頁面使用快取(用cache_page裝飾器)
- 配置檔案中配置快取
- 檢視層實現快取
from django.views.decorators.cache import cache_page
import time
from .models import *
# 單頁面使用,用cache_page裝飾器
@cache_page(15) #超時時間為15秒
def index(request):
t=time.time() #獲取當前時間
bookList=Book.objects.all()
return render(request,"index.html",locals())
2、全域性使用快取(通過中介軟體實現)
- 使用者的請求通過中介軟體,經過一系列的認證等操作,如果請求的內容在快取中存在,則使用
FetchFromCacheMiddleware
獲取內容並返回給使用者 - 當返回給使用者之前,判斷快取中是否已經存在,如果不存在,則
UpdateCacheMiddleware
會將快取儲存至Django的快取之中,以實現全站快取 - 請求來了,是從上到下入走中介軟體;響應的時候是從下到上走中介軟體。因此,獲取頁面放在最後,儲存頁面放最前面
MIDDLEWARE = [
# 放頁面的時候,應該放在最前面
'django.middleware.cache.UpdateCacheMiddleware',
'django.middleware.security.SecurityMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
# 取頁面放在這個位置
'django.middleware.cache.FetchFromCacheMiddleware', #最後
]
3、頁面的區域性使用快取
# 在模板層
{% load cache %}
# 第一個引數是時間,第二個引數是別名
{% cache 5 'test' %}
# 內部的東西會做快取
# 快取的時間:
{{ ctime }}
{% endcache %}