基于Django实现日志记录报错信息
这篇文章主要介绍了基于Django实现日志记录报错信息,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
当服务器500错误的时候,普通日志只会记录一行500的request信息,并不会记录详细的报错定位
[ERROR]2019-06-1215:07:03,597"GET/api/v1/test/HTTP/1.1"50074196
需要添加一个在日志中记录详细错误信息的middleware
#-*-coding:UTF-8-*- importlogging logger=logging.getLogger('default') classExceptionLoggingMiddleware(object): defprocess_exception(self,request,exception): importtraceback logger.error(traceback.format_exc())
将此中间件添加到settings的MIDDLEWARE_CLASSES中
MIDDLEWARE_CLASSES=( 'utils.my_middleware.ExceptionLoggingMiddleware', )
使用Djangologger
'loggers':{ 'django':{ 'handlers':['file','console'], 'level':'INFO' },
效果
[ERROR]2019-06-1215:07:02,265InternalServerError:/api/v1/test/ Traceback(mostrecentcalllast): File"E:\tcp_check\venv\lib\site-packages\django\core\handlers\exception.py",line35,ininner response=get_response(request) File"E:\tcp_check\venv\lib\site-packages\django\core\handlers\base.py",line128,in_get_response response=self.process_exception_by_middleware(e,request) File"E:\tcp_check\venv\lib\site-packages\django\core\handlers\base.py",line126,in_get_response response=wrapped_callback(request,*callback_args,**callback_kwargs) File"E:\tcp_check\tcp_test_app\views.py",line23,intest a=1/0 ZeroDivisionError:divisionbyzero [ERROR]2019-06-1215:07:03,597"GET/api/v1/test/HTTP/1.1"50074196
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。