Django日志和错误的位置
我已经用nginx设置了django服务器,并且在一些页面中出现了403错误。
我在哪里可以finddjango日志? 我在哪里可以看到详细的错误?
日志在settings.py
文件中settings.py
。 一个新的默认项目如下所示:
# A sample logging configuration. The only tangible logging # performed by this configuration is to send an email to # the site admins on every HTTP 500 error when DEBUG=False. # See http://docs.djangoproject.com/en/dev/topics/logging for # more details on how to customize your logging configuration. LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'filters': { 'require_debug_false': { '()': 'django.utils.log.RequireDebugFalse' } }, 'handlers': { 'mail_admins': { 'level': 'ERROR', 'filters': ['require_debug_false'], 'class': 'django.utils.log.AdminEmailHandler' } }, 'loggers': { 'django.request': { 'handlers': ['mail_admins'], 'level': 'ERROR', 'propagate': True, }, } }
默认情况下,这些不会创build日志文件。 如果你想要这些,你需要添加一个filename
参数给你的handlers
'applogfile': { 'level':'DEBUG', 'class':'logging.handlers.RotatingFileHandler', 'filename': os.path.join(DJANGO_ROOT, 'APPNAME.log'), 'maxBytes': 1024*1024*15, # 15MB 'backupCount': 10, },
这将build立一个旋转的日志,可以得到15 MB的大小,并保持10个历史版本。
在上面的loggers
部分中,您需要将applogfile
添加到您的应用程序的handlers
程序
'loggers': { 'django.request': { 'handlers': ['mail_admins'], 'level': 'ERROR', 'propagate': True, }, 'APPNAME': { 'handlers': ['applogfile',], 'level': 'DEBUG', }, }
这个例子会把你的日志放在一个名为APPNAME.log
的文件中的Django根目录APPNAME.log
安装https://docs.djangoproject.com/en/dev/topics/logging/ ,然后这些错误会回应你指向他们的地方。 默认情况下,它们倾向于在杂草中脱落,所以我总是在开始之前先做好测井设置。
这是一个非常好的基本设置的例子: https : //ian.pizza/b/2013/04/16/getting-started-with-django-logging-in-5-minutes/
添加到你的settings.py
:
LOGGING = { 'version': 1, 'disable_existing_loggers': False, 'handlers': { 'file': { 'level': 'DEBUG', 'class': 'logging.FileHandler', 'filename': 'debug.log', }, }, 'loggers': { 'django': { 'handlers': ['file'], 'level': 'DEBUG', 'propagate': True, }, }, }
它会在你的根目录下创build一个名为debug.log
的文件。 https://docs.djangoproject.com/en/1.10/topics/logging/