Django項目緩存優(yōu)化的介紹及具體使用

這篇文章主要講解了“Django項目緩存優(yōu)化的介紹及具體使用”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Django項目緩存優(yōu)化的介紹及具體使用”吧!

創(chuàng)新互聯(lián)是專業(yè)的山陰網(wǎng)站建設公司,山陰接單;提供成都網(wǎng)站設計、做網(wǎng)站,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行山陰網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

一、為什么要使用緩存

大家可以想一下Django的請求響應流程:

→ 用戶瀏覽器輸入URL地址

→ Web服務器將HTTP請求轉(zhuǎn)發(fā)給uWSGI服務器

→ uWSGI服務器將Request請求轉(zhuǎn)發(fā)給Django應用

→ Django中間件處理Request請求

→ 視圖View處理

→ 模型類Models獲取數(shù)據(jù)

→ 模板Template渲染

→ 再次經(jīng)過Django中間件返回

→ uWSGI服務器將Response返回給Web服務器

→ Web服務器響應客戶端的HTTP請求。

這其中耗時最多的2個環(huán)節(jié)通常是視圖中業(yè)務邏輯處理和從Models獲取數(shù)據(jù)(SQL查詢),對于相同目的請求,也就是業(yè)務處理邏輯和SQL查詢的數(shù)據(jù)都一樣的請求,每次都進行了重復的計算,并且數(shù)據(jù)是從硬盤讀取而非內(nèi)存。

所以使用緩存有如下好處:

  • 降低服務器負載

  • 避免重復計算

  • 提高系統(tǒng)性能

二、如何進行緩存

很簡單,一個Request請求過來,先去緩存中查詢,有就返回;沒有就去數(shù)據(jù)庫查詢并處理,然后把結(jié)果緩存好(供下次請求使用),再返回。用偽代碼解釋的話就是這樣

Django項目緩存優(yōu)化的介紹及具體使用

三、緩存的類型

1. Memcached 效率最高,最快的緩存
2. Database caching 數(shù)據(jù)庫緩存,這個指把數(shù)據(jù)緩存到數(shù)據(jù)表,比如你項目中使用的MySQL,就在MySQL中建表來專門緩存數(shù)據(jù)。不是指用redis數(shù)據(jù)庫
3. Filesystem caching 文件系統(tǒng)緩存,將緩存會把鍵值存儲到獨立的文件中去
4. Local-memory caching 使用系統(tǒng)內(nèi)存緩存
5. Dummy caching (for development) 假緩存,只在開發(fā)過程中使用,以調(diào)試緩存接口,數(shù)據(jù)并沒有真正緩存
6. Using a custom cache backend 自定義緩存后端,比如使用Redis

那么問題來了,我該使用哪種緩存呢?

其實常用的也就2種:Memcached或者Reids,其它基本不用考慮了。Redis國內(nèi)用得多,支持RDB和AOF兩種持久化方式,支持高可用集群,技術和方案很成熟。Memcached是純內(nèi)存存儲,本身不支持持久化,不支持分布式,但是它內(nèi)存管理效率高。

四、緩存粒度分類

  1. Per-site cache 把整個網(wǎng)站都緩存了,只需要在項目中設置加入緩存中間鍵的配置,系統(tǒng)便會自動對整個網(wǎng)站進行緩存

  2. Per-view cache 緩存某個視圖

  3. Template fragment caching 模板的片段,比如Django模板繼承base.html,通常是不變的導航欄

  4. Low-level cache API 低級別緩存API,比如緩存某個函數(shù)的結(jié)果,或者某個API接口

那么問題又來了,項目中我該選擇什么樣的緩存粒度?

是否需要緩存很簡單,看內(nèi)容是否變化。如果整個視圖的數(shù)據(jù)通常都不變,就使用視圖緩存,某些模板片段的數(shù)據(jù)不變就使用模板片段緩存等等。所以一個項目里面多種緩存粒度都有的

Django項目緩存優(yōu)化的介紹及具體使用

五、Django緩存設置

這里只說一下Redis和Memcached的,其它很少用的就不羅列了,需要注意的是系統(tǒng)上要安裝對應的緩存服務,Django開發(fā)環(huán)境中要安裝連接緩存服務的包(比如django-redis或pymemcache)

Memcache緩存設置

最簡單的,配置地址和端口,不一定是要在本機,也可以是其它網(wǎng)段的服務器或集群

Django項目緩存優(yōu)化的介紹及具體使用

在本機的話,也可以使用unix Socket

Django項目緩存優(yōu)化的介紹及具體使用

也可以使用多態(tài)服務器,不同端口緩存

Django項目緩存優(yōu)化的介紹及具體使用

Redis緩存設置

截圖一下實戰(zhàn)課程中Redis緩存的配置,緩存網(wǎng)站的數(shù)據(jù)

Django項目緩存優(yōu)化的介紹及具體使用

Django channels頻道層的緩存

Django項目緩存優(yōu)化的介紹及具體使用

Celery緩存,broker和任務的執(zhí)行結(jié)果

Django項目緩存優(yōu)化的介紹及具體使用

六、緩存的使用

對于Django項目緩存的數(shù)據(jù),我們?nèi)〕鰜砘虼孢M去操作,可以不需要直接操作底層的緩存數(shù)據(jù),比如使用原生的Redis或Memcached命令,只需要使用Django提供的緩存API即可。就像我們使用Django ORM一樣,無需關注底層數(shù)據(jù)庫是MySQL, PostgreSQL或SQLite,ORM語句都一樣。

例如,訪問緩存

Django項目緩存優(yōu)化的介紹及具體使用

使用緩存

Django項目緩存優(yōu)化的介紹及具體使用

除了set(), get()還有get_or_set(), get_many(), set_many(), delete(), delete_many(), clear(), touch(), incr(), decr(), close()操作。大家可以去看看官網(wǎng)文檔一個個操作下,要注意的是有的API不是每一個Django版本都有,比如cache.touch()是Django 2.1版本才有的。

七、Django緩存優(yōu)化性能評估

緩存使用了,那效果怎么樣,有什么指標可以衡量?用什么工具來衡量?

Django Debug Toolbar

這點在之前的Python學習教程中有跟大家講到過!

django-debug-toolbar是一個開源的工具,可以在看板上展示django對request/response處理的詳細信息,比如當前請求響應的CPU耗時,settings/headers/request信息,當前請求使用的模板文件,靜態(tài)文件,具體SQL語句和執(zhí)行時間等等,看板要顯示什么信息是可以靈活配置的。

右邊的欄目就是django-debug-tool的看板

Django項目緩存優(yōu)化的介紹及具體使用

此頁面共有9次SQL查詢,耗時8.62毫秒

Django項目緩存優(yōu)化的介紹及具體使用

緩存命中3次,cache.get(),用時約0.91毫秒

Django項目緩存優(yōu)化的介紹及具體使用

感謝各位的閱讀,以上就是“Django項目緩存優(yōu)化的介紹及具體使用”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對Django項目緩存優(yōu)化的介紹及具體使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!

網(wǎng)站標題:Django項目緩存優(yōu)化的介紹及具體使用
新聞來源:http://muchs.cn/article32/pihisc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供自適應網(wǎng)站、標簽優(yōu)化網(wǎng)站營銷、網(wǎng)頁設計公司、企業(yè)建站、網(wǎng)站收錄

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設