6

我只想能够覆盖设置文件中的控制台日志级别。我阅读了django 日志记录文档,但我无法让日志记录按照我的意愿进行。该文件向我保证:

“从 Django 1.5 开始,项目的日志记录配置与 Django 的默认配置合并,因此您可以决定是否要添加或替换现有配置。要完全覆盖默认配置,请在 LOGGING dictConfig 中将 disable_existing_loggers 键设置为 True . 或者,您可以重新定义部分或全部记录器。”

所以我尝试将以下内容添加到我的 settings.py 中:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'handlers': {
        'console':{
            'level': 'DEBUG',
        },
    },
}

...但我得到一个例外:

<snip>
  File "/usr/lib/python2.7/logging/config.py", line 575, in configure
    '%r: %s' % (name, e))
ValueError: Unable to configure handler 'console': 'NoneType' object has no attribute 'split'

很公平。它似乎想要整个配置块。所以我尝试了我认为最简单的控制台记录器配置:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': True,
    'formatters': {
        'simple': {
            'format': '%(levelname)s %(message)s'
        },
    },
    'handlers': {
        'console':{
            'level': 'INFO',
            'class': 'logging.StreamHandler',
            'formatter': 'simple'
        },
    },
    'loggers': {
        'default': {
            'handlers': ['console'],
            'level': 'INFO',
            'filters': []
        }
    }
}

我的意图是将日志级别设置为 INFO,但我仍然看到一堆 DEBUG 消息,并且字符串 MYFORMATTER 无论如何都没有出现在其中任何一个中。

最后,带着盲目的乐观,我尝试了这个:

from django.utils.log import DEFAULT_LOGGING
DEFAULT_LOGGING['handlers']['console']['level'] = 'INFO'

我必须在这里遗漏一些非常明显的东西。

顺便说一句,我使用的是 Django 1.5.1。

4

3 回答 3

5

在这里回答我自己的问题,我最终在 settings.py 文件中使用了以下内容:

import logging

logging.basicConfig(
    level = logging.INFO,
    format = " %(levelname)s %(name)s: %(message)s",
)
于 2013-07-24T17:37:32.220 回答
0

您可以这样做来设置 django 日志记录级别:

import logging
logging.disable(logging.INFO)

日志记录.禁用(lvl)

为所有记录器提供一个覆盖级别 lvl,它优先于记录器自己的级别。当需要暂时降低整个应用程序的日志输出时,此功能可能很有用。它的作用是禁用所有严重级别为 lvl 及以下的日志记录调用,因此如果您使用 INFO 值调用它,则所有 INFO 和 DEBUG 事件将被丢弃,而严重级别为 WARNING 及以上的事件将根据记录器的处理有效水平。要撤消调用 logging.disable(lvl) 的效果,请调用 logging.disable(logging.NOTSET)。

http://docs.python.org/2/library/logging.html#logging.disable

于 2013-07-19T21:09:29.920 回答
0

我有一个类似的问题——我的一个处理程序错过了一个“课程”。

于 2014-04-16T15:26:59.130 回答