您好,登錄后才能下訂單哦!
小編給大家分享一下Django中緩存Cache指的是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家學習,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去學習方法吧!
緩存(Cache)對于創(chuàng)建一個高性能的網(wǎng)站和提升用戶體驗來說是非常重要的,然而對我們這種只用得起拼多多的碼農(nóng)而言最重要的是學會如何使用緩存。今天我們就來看看緩存Cache應用場景及工作原理吧,并詳細介紹如何在Django中設置Cache并使用它們。
什么是緩存Cache
緩存是一類可以更快的讀取數(shù)據(jù)的介質(zhì)統(tǒng)稱,也指其它可以加快數(shù)據(jù)讀取的存儲方式。一般用來存儲臨時數(shù)據(jù),常用介質(zhì)的是讀取速度很快的內(nèi)存。一般來說從數(shù)據(jù)庫多次把所需要的數(shù)據(jù)提取出來,要比從內(nèi)存或者硬盤等一次讀出來付出的成本大很多。對于中大型網(wǎng)站而言,使用緩存減少對數(shù)據(jù)庫的訪問次數(shù)是提升網(wǎng)站性能的關鍵之一。
為什么要使用緩存Cache
在Django中,當用戶請求到達視圖后,視圖會先從數(shù)據(jù)庫提取數(shù)據(jù)放到模板中進行動態(tài)渲染,渲染后的結果就是用戶看到的網(wǎng)頁。如果用戶每次請求都從數(shù)據(jù)庫提取數(shù)據(jù)并渲染,將極大降低性能,不僅服務器壓力大,而且客戶端也無法即時獲得響應。如果能將渲染后的結果放到速度更快的緩存中,每次有請求過來,先檢查緩存中是否有對應的資源,如果有,直接從緩存中取出來返回響應,節(jié)省取數(shù)據(jù)和渲染的時間,不僅能大大提高系統(tǒng)性能,還能提高用戶體驗。
我們來看一個實際的博客例子。每次當我們訪問首頁時,下面視圖都會從數(shù)據(jù)庫中提取文章列表,并渲染的模板里去。大多數(shù)情況下,我們的博客不會更新得那么頻繁,所以文章列表是不變的。這樣用戶在一定時間內(nèi)多次訪問首頁時都從數(shù)據(jù)庫重新讀取同樣的數(shù)據(jù)是一種很大的浪費。
from django.shortcuts import render def index(request): # 讀取數(shù)據(jù)庫等并渲染到網(wǎng)頁 article_list = Article.objects.all() return render(request, 'index.html', {'article_list': article_list})
使用緩存Cache就可以幫我們解決這個問題。當用戶首次訪問博客首頁時,我們從數(shù)據(jù)庫中提取文章列表,并將其存儲到緩存里(常用的是內(nèi)存,這取決于你的設置)。當用戶在單位時間內(nèi)再次訪問首頁時, Django先檢查緩存是否過期(本例是15分鐘), 再檢查緩存里文章列表資源是否存在,如果存在,直接從緩存中讀取數(shù)據(jù), 并渲染模板。
from django.shortcuts import render from django.views.decorators.cache import cache_page @cache_page(60 * 15) # 秒數(shù),這里指緩存 15 分鐘 def index(request): article_list = Article.objects.all() return render(request, 'index.html', {'article_list': article_list})
注意: 在Django中使用緩存前,我們必需先做必要的設置。
緩存Cache的應用場景
緩存主要適用于對頁面實時性要求不高的頁面。存放在緩存的數(shù)據(jù),通常是頻繁訪問的,而不會經(jīng)常修改的數(shù)據(jù)。我們來舉幾個應用例子:
1.博客文章。假設用戶一天更新一篇文章,那么可以為博客設置1天的緩存,一天后會刷新。
2.購物網(wǎng)站。商品的描述信息幾乎不會變化,而商品的購買數(shù)量需要根據(jù)用戶情況實時更新。我們可以只選擇緩存商品描述信息。
3.緩存網(wǎng)頁片段。比如緩存網(wǎng)頁導航菜單和腳部(Footer)。
Django緩存設置
Django中提供了多種緩存方式,如果要使用緩存,需要先在settings.py中進行配置,然后應用。根據(jù)緩存介質(zhì)的不同,你需要設置不同的緩存后臺Backend。
Memcached緩存
Memcached是基于內(nèi)存的緩存,Django原生支持的最快最有效的緩存系統(tǒng)。對于大多數(shù)場景,我們推薦使用Memcached,數(shù)據(jù)緩存在服務器端。使用前需要通過pip安裝memcached的插件python-memcached和pylibmc,可以同時支持多個服務器上面的memcached。
下面是使用pyhon-memcached的設置。
# localhost CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.memcached.MemcachedCache', 'LOCATION': '127.0.0.1:11211', } } # unix soket 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', ] # 我們也可以給緩存機器加權重,權重高的承擔更多的請求,如下 'LOCATION': [ ('172.19.26.240:11211',5), ('172.19.26.242:11211',1), ] } }
數(shù)據(jù)庫緩存
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.db.DatabaseCache', 'LOCATION': 'my_cache_table', }
文件系統(tǒng)緩存
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.filebased.FileBasedCache', 'LOCATION': '/var/tmp/django_cache',#這個是文件夾的路徑 #'LOCATION': 'c:\foo\bar',#windows下的示例 } }
本地內(nèi)存緩存
CACHES = { 'default': { 'BACKEND': 'django.core.cache.backends.locmem.LocMemCache', 'LOCATION': 'unique-snowflake' } }
以上是Django中緩存Cache指的是什么的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。