我对django如何处理日志记录感到有点困惑。我在我的设置中为记录器设置了这个设置:
LOGGING = {
...
'handlers': {
'console': {
'class': 'logging.StreamHandler',
'formatter': 'verbose',
},
'file': {
'level': 'DEBUG',
'class': 'logging.handlers.RotatingFileHandler',
'filename': LOG_BASE_DIRECTORY + '/django.log',
'maxBytes': LOGFILE_SIZE,
'backupCount': LOGFILE_COUNT,
'formatter': 'verbose'
},
'mail_admins': {
'level': 'ERROR',
#'filters': ['require_debug_false'],
'class': 'django.utils.log.AdminEmailHandler'
}
},
'loggers': {
'django': {
'handlers': ['file','mail_admins'],
'level': 'INFO',
'propagate': True,
},
'app1': {
'handlers': ['file','mail_admins'],
'level': 'DEBUG',
'propagate': True,
},
...
},
}
正如我所看到的,我有两个为django和app日志定义的处理程序,文件和 mail_admins。文件的日志级别是debug。因此,我假设所有调试及以上的日志都将使用此处理程序。 mail_admins的级别是错误的。我看到的问题是,如果在电子邮件处理程序运行并发送邮件时发生500错误,则不会记录该文件。
答案 0 :(得分:-2)
要记录错误,您需要在代码中记录它们。像这样的东西
import logging
try:
# your code here
except Exception as e:
logging.getLogger("logger_name").error(repr(e))
请参考this official doc link获取相同或this article视频和工作github代码。