1.一次性取出你所需要的数据

单一动作,需要多次连接数据库里的时候,最好一次性取出所有需要的数据,减少连接数据库的次数。此类需求推荐使用QuerySet.select_related()和prefetch_related()

相反,别取出你不需要的东西,模板templateds里往往只需要实体的某几个字段而不是全部,这时使用queryset.values()和values_list()对你有用,他们只取出你需要的字段,返回字典dict和列表list类型的东西,在模板里面够用就可以,这可以减少内存损耗,提高性能。

使用queryset.count()代替len(queryset),虽然这两个处理出来的结果是一样的,但是前者性能优秀很多。同理判断记录存在的时候,queryset.exists()比if queryset实在强的太多了。

当然一样的结果,当缓存里面已经存在的时候,就别再滥用count(),exitst(),all()函数了。

2.减少数据库连接的次数

使用queryset.update()和delete(),这两个函数是可以批量处理多条记录的,使他们事半功倍;如果可以,被一条条数据去update  delete处理,对于一次性取出来的关联记录,获取外键的时候,直接取关联表的属性,而不是取关联属性,如entry.blog.id优于enrty.blog_id

3.在配置使用相对路径

某些原因使得项目可能常常会被来回的迁移,如果事先没有规划好这种可能性的话,这绝对是一个棘手的问题,有一个极好的技巧能够确保你的Django项目在部署的过程中能够轻松来回迁移,仅仅只需要编写几行代码就可以在你的配置文件settings.py中。、

import  os

BASE_DIR=os.path.dirname(os.path.abspath(__file__)

TEMPLATE_DIRS=(

BASE_DIR+'/templates',

)

4.使用Django-chunks

除了使用Django的富文本编辑器创建模块更日益之外,Django-chunks同样是用于模块中,这个是重用代码块必不可少的工具。

5.使用缓存

如果性能在你的DJango项目中已经成为棘手的问题,那么你将需要使用一些缓存策略,然而Django为缓存提供很多的选择,目前最好的无疑是Memcache,用Django安装memcache非常的简单,如果你使用memcache模块的时候,只要模块安装完成后,你仅仅修改一行配置项,你的Django页面变得轻快起来。

6.Django-debug-toolbar

它是一个非常方便的工具,可以深入了解代码的工作以及它花费了多少时间。特别是他可以显示你的页面生成的SQL查询,以及每个人花了多少时间。

一个在github上面的开源项目:https://github.com/dcramer/django-devserver

很棒的一个可视化工具,但是缺点只能处理text/html类型的response,因为是通过中间件修改返回的html代码实现的

解决方法:开源使用这个库,django-debug-panel

在配合链接中最后的chorme插件来使用,就可以查看所有异步请求中的详细信息。

优点:

统计了总的sql查询时间

重复查询的sql的数量,在每条sql详细信息中显示重复的次数。

执行了sql的具体代码位置

sql语句的高亮

sql查询到的数据结果。

配置参考:

# debug_toolbar settings
if DEBUG:
INTERNAL_IPS = ('127.0.0.1',)
MIDDLEWARE_CLASSES = (
# 'debug_toolbar.middleware.DebugToolbarMiddleware',
'debug_panel.middleware.DebugPanelMiddleware',
) + MIDDLEWARE_CLASSES INSTALLED_APPS += (
'debug_toolbar',
'debug_panel',
) if settings.DEBUG:
import debug_toolbar
urlpatterns = [
url(r'^__debug__/', include(debug_toolbar.urls)),
] + urlpatterns

第三方面板也可以用于工具栏,可以(例如)报告缓存性能和模板呈现时间。
Third-party services

有一些免费服务奖从远程HTTP客户端的角度分析和报告您的网站的页面的性能,实际上模拟实际用户的体验。

这些不能报告您的代码的内部,但是可以提供有用的洞察您的网站的整体性能,包括不能从DJango环境中充分测量的方面。

实例包括:

雅虎Yslow

George pagespeed

还有一些付费服务执行类似的分析,包括一些是Django感知的,可以与您的代码库继承,以更广泛的分析其性能。

7.line  profiler

最好用的还是去line  profiler去找程序的瓶颈,显示一个方法内哪行代码运行的时间最久。

8.在较低级别而不是较高的级别执行此工作计划总是更快。在更高层次,系统必须通过多级抽象和多层机械来处理对象。

也就是说,数据库通常可以比python更快的完成事情,这样比模板语言更快。

9.HTTP performance

Middleware

Django附带了一些有用的middleware,可以帮助优化您的网站的性能,他们包括

conditionGetMiddleware

添加了对现代浏览器的支持,可以根据ETag和Last-Modified标头有条件的获取响应。
GzipMiddleware

压缩所有现代浏览器的响应,节省带宽和传输时间,亲注意,GzipMiddleware目前被认为是一种安全风险,并且容易受到TSL/SSL提供的保护无效的攻击,有关详细的信息,请参阅GzipMiddleware中的警告。

10.Session

Using Cached session

Using  Cached session可能是一种通过消除从像数据库这样比较慢的存储源加载的会话数据而改为经常使用的会话数据存储在内存中来提高性能的方法。

11.Static  Files

静态文件,根据定义是不动态的,使优化增益的一个优秀的目标。

Minification

一些第三方Django工具和包提供了缩小HTML,css,javascript的能力,他们删除不必要的空格,换行符和注释,缩短变量名,从而减少您的网站发布文档的大小。

12.Template  Performance

注意:

使用{% 阻止 %} 比使用{% 包括 %}

从许多小块的组装的重碎片模块可能会影响性能。

The  cached  template   loader

启用cache  temolate  loader通常会大幅提高性能,因为它避免每次需要时编译每个模板渲染。
13.在代码方面的优化

核心模块使用cpython来实现,大幅度提高代码的运行速度。

Django性能优化的几种方法的更多相关文章

  1. Spring/Hibernate 应用性能优化的7种方法

    对于大多数典型的 Spring/Hibernate 企业应用而言,其性能表现几乎完全依赖于持久层的性能.此篇文章中将介绍如何确认应用是否受数据库约束,同时介绍七种常用的提高应用性能的速成法.本文系 O ...

  2. vue-cli 项目优化之3种方法对比:本地静态库资源(推荐)、cdn、DllPlugin

    vue-cli 项目优化之3种方法对比:本地静态库资源(推荐).cdn.DllPlugin 事项 本地静态库资源 cdn DllPlugin 依赖 依赖cdn网站资源(有种完善方法:如果cdn引入不成 ...

  3. django查询表记录的十三种方法

    django查询表记录的十三种方法 all() 结果为queryset类型 >>> models.Book.objects.all() <QuerySet [<Book: ...

  4. Web 性能优化:21 种优化 CSS 和加快网站速度的方法

    这是 Web 性能优化的第 4 篇,上一篇在下面看点击查看: Web 性能优化:使用 Webpack 分离数据的正确方法 Web 性能优化:图片优化让网站大小减少 62% Web 性能优化:缓存 Re ...

  5. django性能优化

    1. 内存.内存,还是加内存 2. 使用单独的静态文件服务器 3. 关闭KeepAlive(如果服务器不提供静态文件服务,如:大文件下载) 4. 使用memcached 5. 使用select_rel ...

  6. Unity性能优化的N种武器

    贴图: l  控制贴图大小,尽量不要超过 1024 x1024: l  尽量使用2的n次幂大小的贴图,否则GfxDriver里会有2份贴图: l  尽量使用压缩格式减小贴图大小: l  若干种贴图合并 ...

  7. sql 优化的几种方法

    .对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. .应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而 ...

  8. sql语句优化的30种方法

    转载于:https://www.cnblogs.com/Little-Li/p/8031295.html 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的 ...

  9. 用django实现redirect的几种方法总结

    用django开发web应用, 经常会遇到从一个旧的url转向一个新的url.这种隐射也许有规则,也许没有.但都是为了实现业务的需要.总体说来,有如下几种方法实现 django的 redirect.1 ...

随机推荐

  1. Focal Loss 理解

    本质上讲,Focal Loss 就是一个解决分类问题中类别不平衡.分类难度差异的一个 loss,总之这个工作一片好评就是了. 看到这个 loss,开始感觉很神奇,感觉大有用途.因为在 NLP 中,也存 ...

  2. hive on spark 释放session资源

    背景 启动hive时,可以看到2.0以后的版本,将要弃用mr引擎,官方建议使用spark,tez等引擎. spark同时支持批式流式处理,可以减少学习成本.所以选用了spark作为执行引擎. hive ...

  3. 镭神激光雷达对于Autoware的适配

    1. 前言 我们的自动驾驶采用镭神激光雷达,在使用Autoware的时候,需要对镭神激光雷达的底层驱动,进行一些改变以适配Autoware. 2. 修改 (1)首先修改lslidar_c32.laun ...

  4. 成都,我们来啦 | Dubbo 社区开发者日

    [关注 阿里巴巴云原生 公众号,回复关键词"报名",即可参与抽奖!] 活动时间:10 月 26 日 13:00 - 18:00 活动地点:成都市高新区交子大道中海国际中心 233 ...

  5. 2019-7-29-win10-UWP-使用-MD5算法

    原文:2019-7-29-win10-UWP-使用-MD5算法 title author date CreateTime categories win10 UWP 使用 MD5算法 lindexi 2 ...

  6. Seata为什么效率高

    1. Seata为什么效率高 1.1. 应对面试官的解释 Seata的解决方案是两阶段提交的升级版,传统两阶段提交资源管理器(RM)放在数据库端,由数据库管理,需要数据库支持XA协议. 而Seata把 ...

  7. Arthas实践--抽丝剥茧排查线上应用日志打满问题

    现象 在应用的 service_stdout.log里一直输出下面的日志,直接把磁盘打满了: 23:07:34.441 [TAIRCLIENT-1-thread-1] DEBUG io.netty.c ...

  8. MYSQL练习随笔

    解法练习 案例1.子查询练习 字段 说明film_id 电影idtitle 电影名称description 电影描述信息category_id 电影分类idname 电影分类名称last_update ...

  9. Django框架(十九)--Django rest_framework-认证组件

    一.什么是认证 只有认证通过的用户才能访问指定的url地址,比如:查询课程信息,需要登录之后才能查看,没有登录,就不能查看,这时候需要用到认证组件 二.利用token记录认证过的用户 1.什么是tok ...

  10. odoo10学习笔记七:国际化、报表

    转载请注明原文地址:https://www.cnblogs.com/ygj0930/p/11189297.html 一:国际化(模块翻译) 我们开发的模块要国际化通用,就要开发出不同的语言支持. 这些 ...