緩存
- 對于中等流量的網(wǎng)站來說,盡可能地減少開銷是必要的。緩存數(shù)據(jù)就是為了保存那些需要很多計算資源的結(jié)果,這樣的話就不必在下次重復消耗計算資源
- Django自帶了一個健壯的緩存系統(tǒng)來保存動態(tài)頁面,避免對于每次請求都重新計算
- Django提供了不同級別的緩存粒度:可以緩存特定視圖的輸出、可以僅僅緩存那些很難生產(chǎn)出來的部分、或者可以緩存整個網(wǎng)站
設(shè)置緩存
- 通過設(shè)置決定把數(shù)據(jù)緩存在哪里,是數(shù)據(jù)庫中、文件系統(tǒng)還是在內(nèi)存中
- 通過setting文件的CACHES配置來實現(xiàn)
- 參數(shù)TIMEOUT:緩存的默認過期時間,以秒為單位,這個參數(shù)默認是300秒,即5分鐘;設(shè)置TIMEOUT為None表示永遠不會過期,值設(shè)置成0造成緩存立即失效
CACHES={
'default': {
'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
'TIMEOUT': 60,
}
}
- 可以將cache存到redis中,默認采用1數(shù)據(jù)庫,需要安裝包并配置如下:
安裝包:pip install django-redis-cache
CACHES = {
"default": {
"BACKEND": "redis_cache.cache.RedisCache",
"LOCATION": "localhost:6379",
'TIMEOUT': 60,
},
}
連接:redis-cli
切換數(shù)據(jù)庫:select 1
查看鍵:keys *
查看值:get 鍵
單個view緩存
- django.views.decorators.cache定義了cache_page裝飾器,用于對視圖的輸出進行緩存
- 示例代碼如下:
from django.views.decorators.cache import cache_page
@cache_page(60 * 15)
def index(request):
return HttpResponse('hello1')
#return HttpResponse('hello2')
- cache_page接受一個參數(shù):timeout,秒為單位,上例中緩存了15分鐘
- 視圖緩存與URL無關(guān),如果多個URL指向同一視圖,每個URL將會分別緩存
模板片斷緩存
- 使用cache模板標簽來緩存模板的一個片段
- 需要兩個參數(shù):
- 示例代碼如下:
{% load cache %}
{% cache 500 hello %}
hello1
<!--hello2-->
{% endcache %}
from django.core.cache import cache
設(shè)置:cache.set(鍵,值,有效時間)
獲?。篶ache.get(鍵)
刪除:cache.delete(鍵)
清空:cache.clear()
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。