1. 程式人生 > >【Django】緩存

【Django】緩存

關於 date 文件 django 請求 ccache 路徑 函數 block


由於Django是動態網站,所以每次請求都會去數據庫中進行響應的操作。
當程序訪問量大時,耗時必然會更加明顯,最簡單的解決方案就是使用緩存。

Django中的緩存:
==即將某一個view的返回值保存至內存或memcache中,默認保存5分鐘。在此時間內如果有人來訪問此view,則不會去執行此view,而是直接從內存或memcache中獲取此view的返回值,並返回.==

Django中提供了6種緩存方式:

  1. 開發調試
  2. 內存
  3. 文件
  4. 數據庫
  5. Memcache緩存(python-memcached模塊)
  6. 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】緩存