记录 Django 命令中的异常

Mar*_*cia 5 python django logging

我已经在 Django 中实现了自定义命令,并且它们的异常未记录在我的日志文件中。

我创建了一个应用程序my_app_with_commands,其中包含一个目录management/commands,我在其中实现了一些命令。

示例命令可能如下所示,由于异常而崩溃:

import logging
from django.core.management.base import BaseCommand


class Command(BaseCommand):
    help = 'Do something usful'
    log = logging.getLogger(__name__)

    def handle(self, *args, **options):
        self.log.info('Starting...')
        raise RuntimeError('Something bad happened')
        self.log.info('Done.')
Run Code Online (Sandbox Code Playgroud)

我的日志配置是这样的:

LOGGING = { 
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'normal': {
            'format': '%(asctime)s %(module)s %(levelname)s %(message)s',
        }
    },  
    'handlers': {
        'file': {
            'level': 'INFO',
            'class': 'logging.FileHandler',
            'filename': os.path.join(BASE_DIR, '..', 'logs', 'my_log.log'),
            'formatter': 'normal',
        },
        'mail_admins': {
            'level': 'ERROR',
            'class': 'django.utils.log.AdminEmailHandler',
            'include_html': True,
        }
    },  
    'loggers': {
        'django': {
            'handlers': ['file'],
            'level': 'INFO',
            'propagate': True,
        },
        'my_app_with_commands': {
            'handlers': ['file', 'mail_admins'],
            'level': 'INFO',
            'propagate': True,
        },
    },  
}
Run Code Online (Sandbox Code Playgroud)

当我运行命令时,对记录器的调用已成功保存到my_log.log文件中:

2016-09-22 11:37:01,514 test INFO Starting...
Run Code Online (Sandbox Code Playgroud)

但是每个回溯的异常都显示在stderr调用命令的位置:

[mgarcia@localhost src]$ ./manage.py test
Traceback (most recent call last):
  File "./manage.py", line 10, in <module>
    execute_from_command_line(sys.argv)
  File "/home/mgarcia/anaconda3/envs/my_env/lib/python3.5/site-packages/django/core/management/__init__.py", line 353, in execute_from_command_line
    utility.execute()
  File "/home/mgarcia/anaconda3/envs/my_env/lib/python3.5/site-packages/django/core/management/__init__.py", line 345, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/home/mgarcia/anaconda3/envs/my_env/lib/python3.5/site-packages/django/core/management/base.py", line 348, in run_from_argv
    self.execute(*args, **cmd_options)
  File "/home/mgarcia/anaconda3/envs/my_env/lib/python3.5/site-packages/django/core/management/base.py", line 399, in execute
    output = self.handle(*args, **options)
  File "/home/mgarcia/my_project/src/my_app_with_commands/management/commands/test_command.py", line 11, in handle
    raise RuntimeError('Something bad happened')
RuntimeError: Something bad happened
Run Code Online (Sandbox Code Playgroud)

我可以在每个命令中实现一个try/except块,并手动记录异常。但是我可以捕获异常并将其保存到我的日志文件中而不是stderr使用 Django 设置吗?

ndp*_*dpu 1

方法之一 - 您可以编辑manage.py文件以在其中添加 try/ except 块:

log = logging.getLogger('my_app_with_commands')
# ...
try:
    execute_from_command_line(sys.argv)
except Exception as e:
    log.error('your exception log')
    raise e
Run Code Online (Sandbox Code Playgroud)