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 中正常工作?
它应该在外壳中正常工作。它对我有用,具有与您相同的日志配置(除了我使用'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 完全相同。
| 归档时间: |
|
| 查看次数: |
4495 次 |
| 最近记录: |