Django日志和调试工具栏实现高效的应用程序调试和性能优化
作者:互联小助手 发布时间:2022-10-25 10:58:01
配置日志
在Django中,可以通过logging模块来记录日志。日志记录器是将日志消息传递给日志处理器的对象。当需要记录日志时,可以使用以下代码来创建一个日志记录器:
import logging
logger = logging.getLogger(__name__)
在创建日志记录器后,可以再创建一个或多个日志处理器来处理日志消息。日志处理器有多个种类,下面是一些常用的日志处理器:
logging.StreamHandler()
- 将日志消息发送到标准输出流logging.FileHandler(filename, mode='a', encoding=None, delay=False)
- 将日志消息写入文件logging.handlers.RotatingFileHandler(filename, mode='a', maxBytes=0, backupCount=0, encoding=None, delay=False)
- 将日志消息写入文件,如果文件的大小超出maxBytes
指定的值,那么将重新生成一个文件来记录日志logging.handlers.TimedRotatingFileHandler(filename, when='h', interval=1, backupCount=0, encoding=None, delay=False)
- 将日志消息写入文件,根据指定的时间间隔和when
参数生成新文件logging.handlers.RotatingFileHandler(filename, mode='a', maxBytes=0, backupCount=0, encoding=None, delay=False)
- 将日志消息写入文件,如果文件的大小超出maxBytes
指定的值,那么将重新生成一个文件来记录日志logging.handlers.SocketHandler(host, port)
- 使用TCP协议,将日志信息发送到指定主机和端口的网络主机上logging.handlers.SMTPHandler(mailhost, fromaddr, toaddrs, subject, credentials=None, secure=None, timeout=1.0)
- 将日志输出到指定的邮件地址logging.MemoryHandler(capacity, flushLevel=ERROR, target=None, flushOnClose=True)
- 将日志输出到内存指定的缓冲区中
上面每个日志处理器都指定了一个名为level
的属性,它代表了日志的级别,不同的日志级别反映出日志中记录信息的严重性。Python中定义了六个级别的日志,按照从低到高的顺序依次是:NOTSET、DEBUG、INFO、WARNING、ERROR、CRITICAL。
日志记录器中配置的日志级别有可能不是最终的日志级别,因为还要参考日志处理器中配置的日志级别,取二者中级别较高者作为最终的日志级别。
Django框架提供了如下所示的内置记录器:
django
- 在Django层次结构中的所有消息记录器django.request
- 与请求处理相关的日志消息。5xx响应被视为错误消息;4xx响应被视为为警告消息django.server
- 与通过runserver调用的服务器所接收的请求相关的日志消息。5xx响应被视为错误消息;4xx响应被记录为警告消息;其他一切都被记录为INFOdjango.template
- 与模板渲染相关的日志消息django.db.backends
- 有与数据库交互产生的日志消息,如果希望显示ORM框架执行的SQL语句,就可以使用该日志记录器。
配置Django-Debug-Toolbar
如果想调试你的Django项目,你一定不能不过名为Django-Debug-Toolbar的神器,它是项目开发阶段辅助调试和优化的必备工具,只要配置了它,就可以很方便的查看到项目运行信息,这些信息对调试项目和优化Web应用性能都是至关重要的。
使用Django-Debug-Toolbar只需要进行以下步骤:
安装Django-Debug-Toolbar。
pip install django-debug-toolbar
修改settings.py
文件:
INSTALLED_APPS = [
'debug_toolbar',
]
MIDDLEWARE = [
'debug_toolbar.middleware.DebugToolbarMiddleware',
]
DEBUG_TOOLBAR_CONFIG = {
# 引入jQuery库
'JQUERY_URL': '<https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js>',
# 工具栏是否折叠
'SHOW_COLLAPSED': True,
# 是否显示工具栏
'SHOW_TOOLBAR_CALLBACK': lambda x: True,
}
修改urls.py
文件:
if settings.DEBUG:
import debug_toolbar
urlpatterns.insert(0, path('__debug__/', include(debug_toolbar.urls)))
在配置好Django-Debug-Toolbar之后,页面右侧会看到一个调试工具栏,上面包括了各种调试信息,例如请求和响应信息、SQL查询、缓存、模板、日志等等。可以通过这些信息来更好地了解Web应用程序的运行情况和性能瓶颈。
优化ORM代码
Django的ORM(Object-Relational Mapping)框架是其最重要的特性之一,它可以将Python对象映射到数据库中的表和列,使得开发者可以使用面向对象的方式来操作数据库。但是,ORM框架也有一些性能上的问题,如果不加以优化,可能会导致Web应用程序的性能瓶颈。
以下是一些优化ORM代码的技巧:
使用select_related
和prefetch_related
select_related
和prefetch_related
是Django ORM框架中用来优化查询性能的两个方法。select_related
可以在查询时一次性获取与主表关联的外键表的数据,而prefetch_related
则可以在查询时一次性获取与主表关联的多对多关系表的数据。这样可以减少查询次数,提高查询性能。
使用annotate
和aggregate
annotate
和aggregate
是Django中用来计算聚合数据的方法。annotate
是用来给查询结果添加新的字段的方法,而aggregate
则是用来对查询结果进行聚合计算的方法。这些方法可以在查询时一次性计算出需要的聚合数据,而不需要在后续的处理中再进行计算。
使用values
和values_list
values
和values_list
是Django ORM框架中用来获取指定字段数据的方法。values
可以返回一个QuerySet对象,其中包含了指定字段的键值对,而values_list
则可以返回一个QuerySet对象,其中包含了指定字段的元组。这些方法可以减少查询结果集的大小,提高查询性能。
使用bulk_create
和bulk_update
bulk_create
和bulk_update
是Django ORM框架中用来批量创建和更新数据的方法。这些方法可以减少数据库操作的次数,提高数据库操作的性能。
使用cache
Django中提供了一个缓存框架,可以将查询结果缓存起来,以减少数据库的访问次数。可以使用cache
装饰器或者cache_page
装饰器来缓存查询结果。
使用raw
查询
Django中的ORM框架虽然方便易用,但是在一些复杂的查询场景中可能性能并不理想。在这种情况下,可以使用raw
查询来直接执行SQL语句,以获得更好的性能。
以上是一些优化ORM代码的技巧,这些技巧可以帮助开发者提高Web应用程序的性能,减少性能瓶颈。在实际开发中,需要根据具体的场景和需求选择合适的优化方法。
来源:https://blog.csdn.net/inchat/article/details/130022902


猜你喜欢
- go for range 遍历二维数组var arry [2][3] intfor index,_ := range arry {fmt.P
- 本文实例讲述了python中range()与xrange()用法。分享给大家供大家参考,具体如下:据说range比xrange开销要大,原因
- adodb.stream对象的方法/属性cancel 方法使用方法如下object.cancel说明:取消执行挂起的异步 execute 或
- 如今我使用 Python 已经很长时间了,但当我回顾之前写的一些代码时,有时候会感到很沮丧。例如,最早使用 Python 时,我写了一个名为
- 选择正确的数据列类型能大大提高数据库的性能和使数据库具有高扩展性。在选择数据列类型时,请从以下几个方面考虑:存放到数据列中的数据类型。数据值
- 什么是 channel 管道它是一个数据管道,可以往里面写数据,从里面读数据。channel 是 goroutine 之间数据通信桥梁,而且
- 存储过程中的TOP后跟一个变量会如何? Create proc getWorkPlan2 (@intCounter int ,@lngUse
- 本文实例讲述了Python中类的创建和实例化操作。分享给大家供大家参考,具体如下:python中同样使用关键字class创建一个类,类名称第
- LinuxNo.1 IPv4下面是IPv4的IP正则匹配实例:简单的匹配给定的字符串是否是ip地址import reif re.match(
- 本文实例讲述了Python爬虫实现抓取京东店铺信息及下载图片功能。分享给大家供大家参考,具体如下:这个是抓取信息的from bs4 impo
- 今天,在家试试django的model的设置,如何设置的联合主键,我经过查资料和实践,把结果记录如下:例如:class user(Model
- 实例如下:<?php/*分治法——直接选择比如说a b c首先将a之后的字符依次与a进行交换1 b,a,c2 c,b,a注意这里少了一
- 源码下载地址网络构建一、什么是SRGANSRGAN出自论文Photo-Realistic Single Image Super-Resolu
- 假设前提:每天晚上10点到早上5点,每10分钟定时执行存储过程。实现方式:第一种是利用Mysql本身实现,制定event定时任务,可以借助N
- 前言由于数据库的类型为Data 类型,所以插入数据库的时候我先把前端传入的string类型的时间转为Time 再插入。Go 提供了两种插入的
- 它是第一个既能用于数据加密也能用于数字签名的算法。它易于理解和操作,也很流行。算法的名字以发明者的名字命名:Ron Rivest, Adi
- 库操作查询1.SHOW DATABASE; ----查询所有数据库2.SHOW CREATE DATABASE 数据库名称; ----查询某
- 爬蟲四步原理:1.发送请求:requests2.获取相应数据:对方及其直接返回3.解析并提取想要的数据:re4.保存提取后的数据:with
- 相信大家都做过九宫格的游戏,规则是要求填数字1-9在九个方格内,使横竖斜相加和相等。只填九个那可能有些简单,但是填25个,填49个,81个等
- 网上商城数据库-用户信息数据操作项目描述在电子商务兴起的大环境下,建立利用互联网开拓销售渠道,帮助企业及时调整商品结构,协助经销商打开货源的