Django緩存

若要緩存一些昂貴的計算結果, 下一次你需要它時不需要再執行它。以下是解釋緩存如何工作的僞代碼−

given a URL, try finding that page in the cache

if the page is in the cache:
return the cached page
else:
generate the page
save the generated page in the cache (for next time)
return the generated page 

Django提供了自己的緩存系統,可以讓您保存動態網頁,爲了避免在需要時重新計算它們。Django緩存架構的優點是,讓你緩存 -

  • 特定視圖的輸出

  • 模板的一部分

  • 整個網站

要使用在Django中使用高速緩存,首先要做的是設置在那裏的緩存會保存下來。高速緩存框架提供了不同的可能性 - 高速緩存可以被保存在數據庫中,關於文件系統,或直接在內存中。可在項目的 settings.py 文件設置完成。

在數據庫設置緩存

只需在項目settings.py文件添加如下-

CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.db.DatabaseCache',
'LOCATION': 'my_table_name',
}

對於這項工作,並完成設置,我們需要創建高速緩存表「my_table_name」。對於這一點,需要做到以下幾點 -

python manage.py createcachetable

在文件系統設置高速緩存


只需在項目settings.py文件添加如下-

CACHES = {
'default': {
'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache',
'LOCATION': '/var/tmp/django_cache',
}
}

設置緩存在內存中


這是緩存的最有效的方法,你可以使用它這取決於Python綁定庫選擇了內存高速緩存,如下列選項之一 -

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',
}
}

緩存整個網站


使用高速緩存在Django的最簡單的方法就是緩存整個網站。這可以通過編輯項目settings.py的MIDDLEWARE_CLASSES選項來完成。以下需要添加到選項-

MIDDLEWARE_CLASSES += (
'django.middleware.cache.UpdateCacheMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.cache.FetchFromCacheMiddleware',
)

請注意,這裏的順序是很重要的,更新應在獲取中間件之前。

然後在同一個文件,還需要設置 -

CACHE_MIDDLEWARE_ALIAS – The cache alias to use for storage.
CACHE_MIDDLEWARE_SECONDS – The number of seconds each page should be cached.

緩存視圖


如果不想緩存整個網站,可以緩存特定視圖。這可通過使用附帶 Django 的 cache_page 修飾符完成。我們要緩存視圖viewArticles的結果-

from django.views.decorators.cache import cache_page

@cache_page(60 * 15)

def viewArticles(request, year, month):
text = "Displaying articles of : %s/%s"%(year, month)
return HttpResponse(text) 

正如你所看到 cache_page 是您希望視圖結果被緩存的需要的秒數(參數)。在上面的例子中,結果將會緩存 15 分鐘。

注 - 正如我們之前看到的上述視圖是映射到 -

urlpatterns = patterns('myapp.views',
url(r'^articles/(?P\d{2})/(?P\d{4})/', 'viewArticles', name = 'articles'),) 

由於URL使用參數,每一個不同的調用將被單獨地執行緩存。例如,請求 /myapp/articles/02/2007 將分別緩存到 /myapp/articles/03/2008。

緩存一個視圖也可以直接在url.py文件中完成。接着下面有相同的結果與上所述。只要編輯 myapp/url.py 文件並更改(以上)的相關映射URL爲 -

urlpatterns = patterns('myapp.views',
url(r'^articles/(?P\d{2})/(?P\d{4})/',
cache_page(60 * 15)('viewArticles'), name = 'articles'),)

當然,它不再需要myapp/views.py。

緩存模板片段


也可以緩存模板的一部分,這是通過使用 cache 標籤進行的。讓我們把 hello.html 模板修改 -

{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% block content %}

Hello World!!!

Today is {{today}}


We are
{% if today.day == 1 %}

the first day of month.
{% elif today == 30 %}

the last day of month.
{% else %}

I don't know.
{%endif%}

{% for day in days\_of\_week %} {{day}}

{% endfor %}
{% endblock %}

緩存內容塊模板將成爲 -

{% load cache %}
{% extends "main_template.html" %}
{% block title %}My Hello Page{% endblock %}
{% cache 500 content %}
{% block content %}

Hello World!!!

Today is {{today}}


We are
{% if today.day == 1 %}

the first day of month.
{% elif today == 30 %}

the last day of month.
{% else %}

I don't know.
{%endif%}

{% for day in days\_of\_week %} {{day}}

{% endfor %}
{% endblock %}
{% endcache %} 

正如你可以在上面看到,緩存標籤將需要2個參數 − 想要的塊被緩存(秒)以及名稱提供給緩存片段。