婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Django程序的優化技巧

Django程序的優化技巧

熱門標簽:遼寧400電話辦理多少錢 電信營業廳400電話申請 江蘇房產電銷機器人廠家 荊州云電銷機器人供應商 溫州旅游地圖標注 外呼不封號系統 幫人做地圖標注收費算詐騙嗎 悟空智電銷機器人6 蘇州電銷機器人十大排行榜

友情提示:

過度性能優化是沒有必要甚至有害的,因為花大力氣帶來的毫秒級的響應提升你的用戶可能根本感知不到,畢竟開發人員的時間也很寶貴。

性能優化指標

在對一個Web項目進行性能優化時,我們通常需要評價多個指標:

  • 響應時間
  • 最大并發連接數
  • 代碼的行數
  • 函數調用次數
  • 內存占用情況
  • CPU占比

其中響應時間(服務器從接收用戶請求,處理該請求并返回結果所需的總的時間)通常是最重要的指標,因為過長的響應時間會讓用戶厭倦等待,轉投其它網站或APP。當你的用戶數量變得非常龐大,如何提高最大并發連接數,減少內存消耗也將變得非常重要。

在開發環境中,我們一般建議使用django-debug-toolbar和django-silk來進行性能監測分析。它們提供了每次用戶請求的響應時間,并告訴你程序執行過程哪個環節(比如SQL查詢)最消耗時間。

對于中大型網站或Web APP而言,最影響網站性能的就是數據庫查詢部分了。一是反復從數據庫讀寫數據很消耗時間和計算資源,二是當返回的查詢數據集queryset非常大時還會占據很多內存。我們先從這部分優化做起。

數據庫查詢優化

利用Queryset的惰性和緩存,避免重復查詢

充分利用Django的QuerySet的惰性和自帶緩存特性,可以幫助我們減少數據庫查詢次數。比如下例中例1比例2要好。因為在你打印文章標題后,Django不僅執行了數據庫查詢,還把查詢到的article_list放在了緩存里,下次可以在其它地方復用,而例2就不行了。

 # 例1: 利用了緩存特性 - Good
 article_list = Article.objects.filter(title__contains="django")
 for article in article_list:
     print(article.title)
 
 # 例2: Bad
 for article in Article.objects.filter(title__contains="django"):
     print(article.title)

但有時我們只希望了解查詢的結果是否存在或查詢結果的數量,這時可以使用exists()和count()方法,如下所示。這樣就不會浪費資源查詢一個用不到的數據集,還可以節省內存。

 # 例3: Good
 article_list = Article.objects.filter(title__contains="django")
 if article_list.exists():
     print("Records found.")
 else:
     print("No records")
     
 # 例4: Good
 count = Article.objects.filter(title__contains="django").count()

一次查詢所有需要的關聯模型數據

假設我們有一個文章(Article)模型,其與類別(Category)是單對多的關系(ForeignKey), 與標簽(Tag)是多對多的關系(ManyToMany)。我們需要編寫一個article_list的函數視圖,以列表形式顯示文章清單及每篇文章的類別和標簽,你的模板文件可能如下所示:

 {% for article in articles %}
    li>{{ article.title }} /li>
    li>{{ article.category.name }}/li>
    li>
        {% for tag in article.tags.all %}
            {{ tag.name }},
        {% endfor %}
    /li>
 {% endfor %}

在模板里每進行一次for循環獲取關聯對象category和tag的信息,Django就要單獨進行一次數據庫查詢,造成了極大資源浪費。我們完全可以使用select_related方法和prefetch_related方法一次性從數據庫獲取單對多和多對多關聯模型數據,這樣在模板中遍歷時Django也不會執行數據庫查詢了。

 # 僅獲取文章數據 - Bad
 def article_list(request):
     articles = Article.objects.all()
     return render(request, 'blog/article_list.html',{'articles': articles, })
 
 # 一次性提取關聯模型數據 - Good
 def article_list(request):
     articles = Article.objects.all().select_related('category').prefecth_related('tags')
     return render(request, 'blog/article_list.html', {'articles': articles, })

僅查詢需要用到的數據

默認情況下Django會從數據庫中提取所有字段,但是當數據表有很多列很多行的時候,告訴Django提取哪些特定的字段就非常有意義了。假如我們數據庫中有100萬篇文章,需要循環打印每篇文章的標題。如果按例4操作,我們會將每篇文章對象的全部信息都提取出來載入到內存中,不僅花費更多時間查詢,還會大量占用內存,而最后只用了title這一個字段,這是完全沒有必要的。我們完全可以使用values和value_list方法按需提取數據,比如只獲取文章的id和title,節省查詢時間和內存(例6-例8)。

 # 例子5: Bad
 article_list = Article.objects.all()
 if article_list:
     print(article.title)
 
 # 例子6: Good - 字典格式數據
 article_list = Article.objects.values('id', 'title')
 if article_list:
     print(article.title)
 
 # 例子7: Good - 元組格式數據
 article_list = Article.objects.values_list('id', 'title')
 if article_list:
     print(article.title)
     
 # 例子8: Good - 列表格式數據
 article_list = Article.objects.values_list('id', 'title', flat=True)
 if article_list:
     print(article.title)

除此以外,Django項目還可以使用defer和only這兩個查詢方法來實現這一點。第一個用于指定哪些字段不要加載,第二個用于指定只加載哪些字段。

使用分頁,限制最大頁數

事實前面代碼可以進一步優化,比如使用分頁僅展示用戶所需要的數據,而不是一下子查詢所有數據。同時使用分頁時也最好控制最大頁數。比如當你的數據庫有100萬篇文章時,每頁即使展示100篇,也需要1萬頁展示給你的用戶,這是完全沒有必要的。你可以完全只展示前200頁的數據,如下所示:

 LIMIT = 100 * 200
 
 data = Articles.objects.all()[:(LIMIT + 1)]
 if len(data) > LIMIT:
     raise ExceededLimit(LIMIT)
 
 return data

數據庫設置優化

如果你使用單個數據庫,你可以采用如下手段進行優化:

  • 建立模型時能用CharField確定長度的字段盡量不用不用TextField, 可節省存儲空間;
  • 可以給搜索頻率高的字段屬性,在定義模型時使用索引(db_index=True);
  • 持久化數據庫連接。

沒有持久化連接,Django每個請求都會與數據庫創建一個連接,直到請求結束,關閉連接。如果數據庫不在本地,每次建立和關閉連接也需要花費一些時間。設置持久化連接時間,僅需要添加CONN_MAX_AGE參數到你的數據庫設置中,如下所示:

 DATABASES = {
     ‘default': {
         ‘ENGINE': ‘django.db.backends.postgresql_psycopg2',
         ‘NAME': ‘postgres',
         ‘CONN_MAX_AGE': 60, # 60秒
    }
 }

當然CONN_MAX_AGE也不宜設置過大,因為每個數據庫并發連接數有上限的(比如mysql默認的最大并發連接數是100個)。如果CONN_MAX_AGE設置過大,會導致mysql 數據庫連接數飆升很快達到上限。當并發請求數量很高時,CONN_MAX_AGE應該設低點,比如30s, 10s或5s。當并發請求數不高時,這個值可以設得長一點,比如60s或5分鐘。

當你的用戶非常多、數據量非常大時,你可以考慮讀寫分離、主從復制、分表分庫的多數據庫服務器架構。這種架構上的布局是對所有web開發語言適用的,并不僅僅局限于Django,這里不做進一步展開了。

緩存

緩存是一類可以更快的讀取數據的介質統稱,也指其它可以加快數據讀取的存儲方式。一般用來存儲臨時數據,常用介質的是讀取速度很快的內存。一般來說從數據庫多次把所需要的數據提取出來,要比從內存或者硬盤等一次讀出來付出的成本大很多。對于中大型網站而言,使用緩存減少對數據庫的訪問次數是提升網站性能的關鍵之一。

視圖緩存

 from django.views.decorators.cache import cache_page
 
 @cache_page(60 * 15)
 def my_view(request):
    ...

使用@cached_property裝飾器緩存計算屬性

對于不經常變動的計算屬性,可以使用@cached_property裝飾器緩存結果。

緩存臨時性數據比如sessions

Django的sessions默認是存在數據庫中的,這樣的話每一個請求Django都要使用sql查詢會話數據,然后獲得用戶對象的信息。對于臨時性的數據比如sessions和messages,最好將它們放到緩存里,也可以減少SQL查詢次數。

 SESSION_ENGINE = 'django.contrib.sessions.backends.cache'

模版緩存

默認情況下Django每處理一個請求都會使用模版加載器都會去文件系統搜索模板,然后渲染這些模版。你可以通過使用cached.Loader開啟模板緩存加載。這時Django只會查找并且解析你的模版一次,可以大大提升模板渲染效率。

 TEMPLATES = [{
     'BACKEND': 'django.template.backends.django.DjangoTemplates',
     'DIRS': [BASE_DIR / 'templates'],
     'OPTIONS': {
         'loaders': [
            ('django.template.loaders.cached.Loader', [
                 'django.template.loaders.filesystem.Loader',
                 'django.template.loaders.app_directories.Loader',
                 'path.to.custom.Loader',
            ]),
        ],
    },
 }]

注意:不建議在開發環境中(Debug=True)時開啟緩存加載,因為修改模板后你不能及時看到修改后的效果。

另外模板文件中建議使用with標簽緩存視圖傳來的數據,便于下一次時使用。對于公用的html片段,也建議使用緩存。

{% load cache %}
 {% cache 500 sidebar request.user.username %}
    .. sidebar for logged in user ..
 {% endcache %}

靜態文件

壓縮 HTML、CSS 和 JavaScript等靜態文件可以節省帶寬和傳輸時間。Django 自帶的壓縮工具有GzipMiddleware 中間件和 spaceless 模板 Tag。使用Python壓縮靜態文件會影響性能,一個更好的方法是通過 Apache、Nginx 等服務器來對輸出內容進行壓縮。例如Nginx服務器支持gzip壓縮,同時可以通過expires選項設置靜態文件的緩存時間。

以上就是Django程序的優化技巧的詳細內容,更多關于Django程序的優化的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Django查詢數據庫的性能優化示例代碼
  • Django的性能優化實現解析
  • 詳解Django配置優化方法
  • Django項目優化數據庫操作總結

標簽:喀什 景德鎮 三沙 宿遷 欽州 黃山 臺灣 濟南

巨人網絡通訊聲明:本文標題《Django程序的優化技巧》,本文關鍵詞  Django,程序,的,優化,技巧,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Django程序的優化技巧》相關的同類信息!
  • 本頁收集關于Django程序的優化技巧的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人一区二区三区视频在线观看 | 亚洲国产日韩一区二区| 日韩一级完整毛片| 精品欧美一区二区三区精品久久| 中文字幕国产精品一区二区| 亚洲精品高清在线观看| 日韩精彩视频在线观看| 99精品热视频| 日韩欧美一区在线观看| 精一区二区三区| 国产伦精品一区二区三区免费 | 99精品1区2区| 欧美日韩一级二级| 91亚洲男人天堂| 亚洲韩国精品一区| 日韩免费观看高清完整版| 久久精品av麻豆的观看方式| 欧美放荡的少妇| 视频一区欧美精品| 91搞黄在线观看| 午夜激情一区二区| 精品国产91乱码一区二区三区 | 日韩一区欧美一区| 免费成人小视频| 国产精品对白交换视频| 久草精品在线观看| 综合欧美一区二区三区| 色八戒一区二区三区| 日韩在线一区二区三区| 久久久亚洲精华液精华液精华液| 视频在线观看一区二区三区| 国产精品日韩成人| 欧美一区二区三区思思人| 91丨九色丨尤物| 奇米888四色在线精品| 久久精品99久久久| 日本不卡的三区四区五区| 亚洲麻豆国产自偷在线| 亚洲无人区一区| 欧美一区二区三区系列电影| 欧美性大战久久久久久久| 成人午夜又粗又硬又大| 国产一区二区三区不卡在线观看| 国产精品 欧美精品| 国产成人午夜精品5599| 欧美丝袜第三区| 欧美嫩在线观看| 91蜜桃传媒精品久久久一区二区| 美女一区二区在线观看| 国产精品12区| 欧美韩国日本综合| 亚洲欧洲日韩女同| 五月激情六月综合| 韩国欧美国产1区| 日韩av一二三| 亚洲成a人v欧美综合天堂下载| 一区二区三区日韩精品视频| 久久久美女艺术照精彩视频福利播放| 亚洲激情av在线| 亚洲欧美区自拍先锋| 麻豆精品久久久| av电影在线不卡| 色综合久久88色综合天天免费| av电影天堂一区二区在线观看| 日本精品裸体写真集在线观看 | 国产精品99久久久久久宅男| 国产综合色产在线精品| 色综合久久中文综合久久牛| 91丨porny丨户外露出| 久久久精品2019中文字幕之3| 国产黄人亚洲片| 日韩欧美成人一区| 成人国产一区二区三区精品| 欧美国产一区在线| 日韩激情一区二区| 成人av在线影院| 亚洲欧美日韩国产综合在线| 欧美日韩中文字幕精品| 国产在线精品免费| 久久久一区二区| 成人av在线影院| 国产午夜久久久久| 中文一区在线播放| 91搞黄在线观看| 麻豆高清免费国产一区| 成人欧美一区二区三区视频网页 | 亚洲综合色噜噜狠狠| 欧美日韩国产高清一区二区| 亚洲二区在线视频| 久久嫩草精品久久久精品| 国产一区二区三区免费播放| 国产精品午夜在线观看| 91在线小视频| 中文字幕人成不卡一区| 99riav一区二区三区| 午夜精品福利一区二区三区av| 日韩欧美一区二区视频| 精品无码三级在线观看视频| 亚洲一区二区三区不卡国产欧美| 色偷偷成人一区二区三区91| 国产精品久久久久久久浪潮网站| 欧美婷婷六月丁香综合色| 成人免费视频app| 看电影不卡的网站| 久久精品久久综合| www日韩大片| 91蝌蚪porny九色| 国产精品三级久久久久三级| 欧美日韩精品欧美日韩精品| 欧美理论在线播放| 蜜桃精品视频在线| 欧美大胆一级视频| 亚洲乱码国产乱码精品精的特点| 欧美一区二区视频在线观看2020 | 久久精品亚洲乱码伦伦中文 | 欧美日韩黄视频| 在线精品视频小说1| 狂野欧美性猛交blacked| 六月丁香婷婷久久| 久久综合国产精品| 欧美xxxxx牲另类人与| 制服.丝袜.亚洲.中文.综合| 92国产精品观看| 激情综合网天天干| 亚洲主播在线观看| 国产精品国产a级| 国产成人精品免费视频网站| 成人精品高清在线| 精品国产一区二区三区av性色| 久久九九久精品国产免费直播| 国产日韩欧美精品一区| 亚洲国产精品欧美一二99| 精品少妇一区二区三区视频免付费| eeuss影院一区二区三区| 91官网在线观看| 亚洲一区二区三区国产| 欧美日韩不卡视频| 狠狠色综合日日| 色哟哟一区二区三区| 91麻豆精品91久久久久久清纯 | 国产精品国产馆在线真实露脸 | 欧美一级高清片| 日韩av在线播放中文字幕| 午夜不卡av在线| 国产高清久久久久| 欧美日韩高清不卡| 日韩影视精彩在线| 日韩高清一区在线| 99久久精品国产毛片| 成人激情午夜影院| 91成人网在线| 欧美日韩日日夜夜| 在线播放欧美女士性生活| 91美女片黄在线观看| 视频一区在线播放| 91精品欧美综合在线观看最新| 94-欧美-setu| 久久久国产一区二区三区四区小说 | 精久久久久久久久久久| 国产成人在线视频免费播放| 欧美一级理论片| 国模无码大尺度一区二区三区| 成人午夜激情影院| 久久这里只精品最新地址| bt欧美亚洲午夜电影天堂| 亚洲一区二区综合| 亚洲图片另类小说| 久久精品在线观看| 欧美天天综合网| 国产精品影视天天线| 成人自拍视频在线| 国产欧美日韩亚州综合| 中文字幕一区日韩精品欧美| av在线播放不卡| 国产成人在线免费观看| 日韩理论片在线| 日韩三级电影网址| 99re这里都是精品| 久久精品国产亚洲高清剧情介绍 | 亚洲色图视频免费播放| 一本到三区不卡视频| 91 com成人网| 99久久久无码国产精品| 麻豆久久久久久| 日韩黄色一级片| 日本一区二区成人| 欧美国产97人人爽人人喊| 精品播放一区二区| 国产精品日韩精品欧美在线| 欧美日韩一级二级三级| www.日本不卡| 成人免费高清视频在线观看| 韩国一区二区三区| 午夜精品久久久久久久 | 欧美少妇性性性| 91在线你懂得| 日韩精品自拍偷拍| 国产精品卡一卡二卡三| 国产精品成人网| 亚洲一区二区在线观看视频|