记录器未配置任何处理程序

时间:2019-02-13 07:09:41

标签: python django logging

我将django的日志记录配置如下:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'django.server': {
            '()': 'django.utils.log.ServerFormatter',
            'format': '[%(server_time)s] %(message)s',
        },
        'verbose': {
            'format': '%(levelname)s %(asctime)s %(module)s %(process)d %(thread)d %(message)s'
        },
        'simple': {
            'format': '%(levelname)s %(message)s'
        },
    },
    'filters': {
        'require_debug_true': {
            '()': 'django.utils.log.RequireDebugTrue',
        },
    },
    'handlers': {
        'django.server': {
            'level': 'INFO',
            'class': 'logging.StreamHandler',
            'formatter': 'django.server',
        },
        'console': {
            'level': 'DEBUG',
            'class': 'logging.StreamHandler',
            'formatter': 'verbose'
        },
        'mail_admins': {
            'level': 'ERROR',
            'class': 'django.utils.log.AdminEmailHandler'
        }
    },
    'loggers': {
        'django': {
            'handlers': ['console'],
            'propagate': True,
        },
        'django.server': {
            'handlers': ['django.server'],
            'level': 'INFO',
            'propagate': False,
        },
        'django.request': {
            'handlers': ['mail_admins', 'console'],
            'level': 'ERROR',
            'propagate': False,
        },
        'django.db.backends': {
            'handlers': ['console'],
            'level': 'INFO'
        },
        'mylogger': {
            'handlers': ['console'],
            'level': 'INFO',
            'propagate': False,
        },
    }
}

在单独的模块中,mylogger的用法如下:

logger = logging.getLogger('mylogger')


def myfunc():
    logger.warning('something')

单步执行代码可以告诉我:

  • 在应用配置之前创建logger实例
  • mylogger已将配置正确地应用于django
  • 但使​​用时,logger实例(应该与mylogger记录器相对应)正确配置了(!?)

我不明白这里发生了什么。

0 个答案:

没有答案