了解django的日志记录

时间:2017-04-26 08:42:48

标签: django logging django-logging

我对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错误,则不会记录该文件。

1 个答案:

答案 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代码。