Django 日志记录不适用于 django shell

roo*_*oob 6 python django logging

我在 Django 应用程序中设置了日志记录,以记录到标准输出和文件。

当我正常运行 django 应用程序时 ( ./manage.py runserver),日志会按预期更新。以下是当我访问以下视图的 url 时成功记录的示例:

# views.py

import logging
logger = logging.getLogger('mylogger')

def test(request):
    logger.error("test")
Run Code Online (Sandbox Code Playgroud)

但是,当我运行./manage.py shell并运行以下命令时,日志不会更新:

import logging
logger = logging.getLogger('mylogger')
logger.error('test')
Run Code Online (Sandbox Code Playgroud)

这是我在 settings.py 中的日志记录设置:

LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
    },
    'handlers': {
        'console': {
            'level': 'INFO',
            'class': 'logging.StreamHandler',
            'stream': sys.stdout,
        },
        'file': {
            'level': 'DEBUG',
            'class': 'logging.FileHandler',
            'filename': '../debug.log',
        },
    },
    'loggers': {
        'mylogger': {
            'handlers': ['console', 'file'],
            'level': 'INFO',
            'propagate': True,
        },
    }
}
Run Code Online (Sandbox Code Playgroud)

我是否需要做一些额外的事情才能使日志记录在 shell 中正常工作?

Vin*_*jip 3

它应该在外壳中正常工作。它对我有用,具有与您相同的日志配置(除了我使用'ext:://sys.stdout'而不是sys.stdout,因为我没有sys导入settings.py.

django20 vinay@ubuntu:/tmp/foo$ tail -25 foo/settings.py 
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'filters': {
    },
    'handlers': {
        'console': {
            'level': 'INFO',
            'class': 'logging.StreamHandler',
            'stream': 'ext://sys.stdout',
        },
        'file': {
            'level': 'DEBUG',
            'class': 'logging.FileHandler',
            'filename': '../debug.log',
        },
    },
    'loggers': {
        'mylogger': {
            'handlers': ['console', 'file'],
            'level': 'INFO',
            'propagate': True,
        },
    }
}

django20 vinay@ubuntu:/tmp/foo$ python manage.py shell
Python 3.5.2 (default, Nov 23 2017, 16:37:01) 
[GCC 5.4.0 20160609] on linux
Type "help", "copyright", "credits" or "license" for more information.
(InteractiveConsole)
>>> import logging; logger = logging.getLogger('mylogger')
>>> logger.error('foo')
foo
>>> logger.warning('bar')
bar
>>> logger.info('baz')
baz
>>> logger.debug('boz')
>>> 

django20 vinay@ubuntu:/tmp/foo$ more ../debug.log 
foo
bar
baz
Run Code Online (Sandbox Code Playgroud)

这是使用新的 virtualenv 和 Django 2.0 安装,但它应该与旧版本的 Django 完全相同。