- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
网站性能优化6法则Python性能优化DjangoQuerySet性能优化
网站性能优化6法则
• 1.尽可能的使用 CSS sprites 技术,多图合并 ,一次请求
• 2.多个 js 文件或多个 Css 文件 进行合并和压缩
• 3.【必须】CSS 放置顶部,JS放置底部
• 4.尽可能的使用外部 JS 和 CSS,减少内联或嵌入式 JS 和 CSS
• 5.减少重复 JS 和 CSS
• 6.【必须】避免重定向 ,尤其是缺少 / 的自动重定向
Python性能优化
• 1.尽量使用 generator(生成器),如 xrange / yield/ dict.iteritems() / itertools
• 2.【必须】正则表达式预编译, pile(…)
• 3.排序尽量使用 .sort(), 其中使用 key 比 cmp 效率更高
• 4.适当使用 list 迭代表达式,如 [i for i in xrane(10)]
• 5.使用 set 来判断元素的存在
• 6.使用 dequeue 来做双端队列
Django QuerySet 性能优化
• 1.【必须】尽量避免读取全部数据,优先使用 exists, count, only, defer, 切片[]
等,如:
1)使用 QuerySet.values() 或 QuerySet.values_list() 获取部分需要的表字段数据
2)使用 QuerySet.Iterator() 迭代大数据
3)只查询数量时用 QuerySet.count(),查询已得结果时用 len(QuerySet)
4)只判断存在时用 QuerySet.exists(),查询已得结果时用 if QuerySet
• 2.外键关联过多,可使用 select_related 提前将关联表进行 join,移除查询读取相
关数据,Many-to-many 则使用 prefetch_related
• 3.建立使用数据库索引
• 4.【必须】使用正确的字段类型,避免 TextField 代替 CharField,IntegerField 代
替 BooleanField等
文档评论(0)