【Django】緩存
阿新 • • 發佈:2018-12-25
關於 date 文件 django 請求 ccache 路徑 函數 block
由於Django是動態網站,所以每次請求都會去數據庫中進行響應的操作。
當程序訪問量大時,耗時必然會更加明顯,最簡單的解決方案就是使用緩存。
Django中的緩存:
==即將某一個view的返回值保存至內存或memcache中,默認保存5分鐘。在此時間內如果有人來訪問此view,則不會去執行此view,而是直接從內存或memcache中獲取此view的返回值,並返回.==
Django中提供了6種緩存方式:
- 開發調試
- 內存
- 文件
- 數據庫
- Memcache緩存(python-memcached模塊)
- Memcache緩存(pylibmc模塊)
配置
***
==開發調試:==
# 開發調試用,實際內部不做任何操作,即不會緩存 CACHES = { ‘default‘: { ‘BACKEND‘: ‘django.core.cache.backends.dummy.DummyCache‘, # 引擎,指定為開發調試 ‘TIMEOUT‘: 300, # 超時時間 ‘OPTIONS‘: { ‘MAX_ENTRIES‘: 300, # 緩存的最大個數(默認300) ‘CULL_FREQUENCY‘: 3, # 緩存超過最大個數後,剔除緩存個數的比例, 即:1/CULL_FREQUENCY(默認3) }, # ‘KEY_PREFIX‘: ‘‘, # 緩存key的前綴(默認空) # ‘VERSION‘: 1, # 緩存key的版本(默認1) # ‘KEY_FUNCTION‘: "函數名", # 生成key的函數(默認函數會生成為【前綴:版本:key】) }, }
==緩存到內存:==
# 此緩存將內容保存至內存的變量中 CACHES = { ‘default‘: { ‘BACKEND‘: ‘django.core.cache.backends.locmem.LocMemCache‘, # 引擎,指定為內存緩存 ‘LOCATION‘: ‘unique-snowflake‘, # 唯一標識 ‘TIMEOUT‘: 300, # 超時時間 ‘OPTIONS‘: { ‘MAX_ENTRIES‘: 300, # 緩存的最大個數(默認300) ‘CULL_FREQUENCY‘: 3 # 緩存超過最大個數後,剔除緩存個數的比例, 即:1/CULL_FREQUENCY(默認3) } } }
==緩存到文件:==
# 此緩存將內容保存至文件
CACHES = {
‘default‘: {
‘BACKEND‘: ‘django.core.cache.backends.filebased.FileBasedCache‘, # 引擎,指定為文件緩存
‘LOCATION‘: ‘/Users/macbook/django_cache‘, # 緩存的文件夾路徑(需要手動創建好文件夾)
}
}
# 註:其他配置同開發調試版本
==緩存到數據庫:==
# 此緩存將內容保存至數據庫 CACHES = { ‘default‘: { ‘BACKEND‘: ‘django.core.cache.backends.db.DatabaseCache‘, ‘LOCATION‘: ‘my_cache_table‘, # 指定數據表 } } # 將以上配置寫好之後,執行命令:python manage.py createcachetable, 將會自動創建數據表
==Memcache緩存(python-memcached模塊):==
# 此緩存使用python-memcached模塊連接memcache
CACHES = {
‘default‘: {
‘BACKEND‘: ‘django.core.cache.backends.memcached.MemcachedCache‘,
‘LOCATION‘: ‘127.0.0.1:11211‘,
}
}
CACHES = {
‘default‘: {
‘BACKEND‘: ‘django.core.cache.backends.memcached.MemcachedCache‘,
‘LOCATION‘: ‘unix:/tmp/memcached.sock‘,
}
}
CACHES = {
‘default‘: {
‘BACKEND‘: ‘django.core.cache.backends.memcached.MemcachedCache‘,
‘LOCATION‘: [
‘172.19.26.240:11211‘,
‘172.19.26.242:11211‘,
]
}
}
==Memcache緩存(pylibmc模塊):==
# 此緩存使用pylibmc模塊連接memcache
CACHES = {
‘default‘: {
‘BACKEND‘: ‘django.core.cache.backends.memcached.PyLibMCCache‘,
‘LOCATION‘: ‘127.0.0.1:11211‘,
}
}
CACHES = {
‘default‘: {
‘BACKEND‘: ‘django.core.cache.backends.memcached.PyLibMCCache‘,
‘LOCATION‘: ‘/tmp/memcached.sock‘,
}
}
CACHES = {
‘default‘: {
‘BACKEND‘: ‘django.core.cache.backends.memcached.PyLibMCCache‘,
‘LOCATION‘: [
‘172.19.26.240:11211‘,
‘172.19.26.242:11211‘,
]
}
}
應用
***
==全站使用:==
使用中間件,經過一系列的認證等操作,如果內容在緩存中存在,則使用FetchFromCacheMiddleware獲取內容並返回給用戶。在返回給用戶之前,判斷緩存中是否已經存在,如果不存在,則UpdateCacheMiddleware會將數據保存至緩存,從而實現全站緩存。
MIDDLEWARE = [
‘django.middleware.cache.UpdateCacheMiddleware‘, # 放緩存(要寫在中間件列表的頭部)
···
# 其它中間件
···
‘django.middleware.cache.FetchFromCacheMiddleware‘, # 獲取緩存(要寫在中間件列表的尾部)
]
# 中間件緩存配置
# CACHE_MIDDLEWARE_SECONDS = 5 # 超時時間(指定int類型)
# CACHE_MIDDLEWARE_ALIAS = ‘‘ # 別名
# CACHE_MIDDLEWARE_KEY_PREFIX = ‘‘ # 關鍵的前綴
==單獨視圖緩存:==
# 方式一:
from django.views.decorators.cache import cache_page # 用於緩存視圖
@cache_page(5) # 指定緩存時間為5秒(默認15*60)
def test(request):
pass
# 方式二:
from django.views.decorators.cache import cache_page # 用於緩存視圖
urlpatterns = [
url(r‘^test/$‘, cache_page(5)(views.test)),
# cache_page(5):指定緩存時間為5秒
# (views.test):執行的視圖函數
]
==局部模版使用:==
# 引入TemplateTag
{% load cache %}
# 使用緩存
{% cache 超時時間(s) 緩存key %}
"""將要緩存的內容寫在此處"""
{% endcache %}
關於Django緩存的更多知識:https://docs.djangoproject.com/en/1.11/topics/cache/
【Django】緩存