国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Django代碼性能優化與Pycharm Profile使用詳解

2020-01-04 14:39:02
字體:
來源:轉載
供稿:網友

前言

pycharm是python的一個商業的集成開發工具,本人感覺做python開發還是很好用的,django是一個很流行的python web開源框架,本文將通過實例代碼給大家介紹了關于Django代碼性能優化與Pycharm Profile使用的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧

是一段導出數據月報的腳本,原先需要十幾秒,優化后只需要1秒多。

Pycharm Profile

優化第一步就是Profile,先看看慢在哪里。Pycharm自帶Profile工具,很方便。 
拿一張官方圖說明一下。

Django,代碼,性能優化,Pycharm,Profile

圖表說明:

  • 給出了函數調用關系。
  • 紅色->黃綠色->綠色,顏色越深說明耗時越多。
  • 右上角的“x數字”代表函數調用次數。
  • Own代表該函數本身的耗時,不包括調用子函數;而Total包括調用子函數的耗時。還給出了耗時的百分比。
  • 可以右鍵“jump to source”,跳到對應的源碼。

有了Profile,剩下的事情就好辦了。

首先,看到了有個工具函數調用了9千多次,這個函數用到了nametupled,花了很多時間,于是把nametupled去掉,節省了好幾秒的時間。

開啟Django logger并設置DEBUG級別

繼續Profile,看到時間主要在ORM查詢數據庫那里。 
這時,開啟Django本身的logger,級別調到DEBUG,這樣就會打印出查詢的SQL語句。

N+1問題

首先意識到的是ORM查詢的N+1問題。 

比如有個Order表,里面有個外鍵user_id是關聯User表.當我們

for order in Order.objects.all(): order.user.id

的時候,Order.objects.all()只有1條sql語句,獲取Order表本身的字段到內存,而不會將關聯的外鍵也獲取。 

當我們order.user_id的時候,不會觸發額外的sql查詢,而order.user.id的時候,會額外查詢User表。 

for循環執行了N次,就額外sql查詢了N次。故叫N+1問題。

解決N+1的方法:

  • 如果是只用到id字段,則可以直接用user_id代替user.id
  • select_related。將相關的表也一同查詢。select_related如果不傳參數,表示查詢所有外鍵的表。

又節省了幾秒的時間。

只查詢需要的字段

繼續看log,發現sql查詢次數是減少了很多,然而sql查詢語句很長,看來是把所有字段都查詢出來。 

然而我很多時候只需要某幾個字段而已,這樣全查出來就浪費了。

解決方法:

  • only()。只查詢想要的字段。比如Order.objects.only(‘user_id', ‘pay_date', ‘price')
  • annotate()。 可指定虛擬字段,如果外鍵關聯的表只用到小部分字段,可以直接annotate過來。比如將User表的realname字段賦給Order表叫user_realname虛擬字段.這樣就不需要order.user.realname查詢,只需要order.user_realname來查詢,不用select_related把user表全部字段給取出來。Order.objects.annotate(user_realname=F(‘user__realname'))。注意還用到了F(),表示純數據庫層面的操作,不需要拉到python內存進行處理。

An F() object represents the value of a model field or annotated column. It makes it possible to refer to model field values and perform database operations using them without actually having to pull them out of the database into Python memory.

至此,將整段代碼的執行時間減少到了1.5秒。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網的支持。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 凤冈县| 邵阳市| 永泰县| 定西市| 凤翔县| 望谟县| 甘德县| 陆丰市| 如东县| 资中县| 屯门区| 伊宁市| 阿瓦提县| 连云港市| 吉水县| 汕头市| 常德市| 临泉县| 姜堰市| 南和县| 南华县| 康定县| 读书| 嵩明县| 大渡口区| 芮城县| 灵山县| 阳东县| 贵港市| 鲁山县| 宜州市| 高州市| 巴南区| 唐河县| 瑞昌市| 集安市| 翁源县| 香格里拉县| 彭阳县| 扎鲁特旗| 大理市|