时间:2021-05-22
这篇文章主要介绍了基于Django实现日志记录报错信息,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
当服务器500错误的时候,普通日志只会记录一行500的request信息,并不会记录详细的报错定位
[ERROR] 2019-06-12 15:07:03,597 "GET /api/v1/test/ HTTP/1.1" 500 74196需要添加一个在日志中记录详细错误信息的middleware
# -*- coding: UTF-8 -*-import logginglogger = logging.getLogger('default')class ExceptionLoggingMiddleware(object): def process_exception(self, request, exception): import traceback logger.error(traceback.format_exc())将此中间件添加到settings的MIDDLEWARE_CLASSES中
MIDDLEWARE_CLASSES = ('utils.my_middleware.ExceptionLoggingMiddleware',)使用Django logger
'loggers': { 'django': { 'handlers': ['file', 'console'], 'level': 'INFO' },效果
[ERROR] 2019-06-12 15:07:02,265 Internal Server Error: /api/v1/test/Traceback (most recent call last): File "E:\tcp_check\venv\lib\site-packages\django\core\handlers\exception.py", line 35, in inner response = get_response(request) File "E:\tcp_check\venv\lib\site-packages\django\core\handlers\base.py", line 128, in _get_response response = self.process_exception_by_middleware(e, request) File "E:\tcp_check\venv\lib\site-packages\django\core\handlers\base.py", line 126, in _get_response response = wrapped_callback(request, *callback_args, **callback_kwargs) File "E:\tcp_check\tcp_test_app\views.py", line 23, in test a=1/0ZeroDivisionError: division by zero[ERROR] 2019-06-12 15:07:03,597 "GET /api/v1/test/ HTTP/1.1" 500 74196以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
shell脚本如何优雅的记录日志信息,下面让我们一步一步,让shell脚本的日志也变得高端起来,实现如下功能①设定日志级别,实现可以输出不同级别的日志信息,方便
解决nginx报错信息clientintendedtosendtoolargebody:1331696bytes1,nginx后台error日志报错2016/0
本文实例讲述了php基于自定义函数记录log日志方法。分享给大家供大家参考,具体如下:/***记录错误日志*@param日志内容$res*/functionsa
1、在Django提交表单时报错:Django提交表单报错:CSRFtokenmissingorincorrect具体报错页面如下:2、有道词典翻译后如下:通常
环境Win10Python3.6.6Django2.1.3中间件作用中间件用于全局修改Django的输入或输出。中间件常见用途缓存会话认证日志记录异常中间件执行