【问题标题】:Gunicorn Django and logging info to a fileGunicorn Django 并将信息记录到文件中
【发布时间】:2013-05-08 17:10:17
【问题描述】:

我正在尝试设置我的日志记录设置以通过 stdoutlogging.info('any message') 发送到文件。

这是我的gunicorn_django 脚本:

$ gunicorn_django -w $NUM_WORKERS --user=$USER --group=$GROUP --log-level=info --log-file=$LOGFILE &>>$LOGFILE

这些是我的日志记录设置:

import sys
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'simple': {
            'format': '%(levelname)s %(message)s'
        },
    },
    'filters': {
        'require_debug_false': {
            '()': 'django.utils.log.RequireDebugFalse'
        }
    },
    'handlers': {
        'console': {
            'level': 'INFO',
            'filters': ['require_debug_false'],
            'class': 'logging.StreamHandler',
            'stream': sys.stdout,
            'formatter': 'simple',
        },
        'mail_admins': {
            'level': 'ERROR',
            'filters': ['require_debug_false'],
            'class': 'django.utils.log.AdminEmailHandler'
        }
    },
    'loggers': {
        'app.location': {
            'handlers': ['console'],
            'level': 'INFO',
            'propagate': False,
        },
        'django.request': {
            'handlers': ['mail_admins'],
            'level': 'ERROR',
            'propagate': True,
        },
    }
}

当我这样做时:

import logging
logging.getLogger('app.location')
logging.info('any message')

它没有记录到gunicorn_django $LOGFILE。 $LOGFILE 中似乎只显示了print >> sys.stderr 消息

如何将信息消息(通过标准输出)记录到文件中

【问题讨论】:

    标签: django logging gunicorn


    【解决方案1】:

    您的记录器会在您创建它后立即收集垃圾。您需要保留对它的引用作为记录器,然后使用该记录器,如下所示:

    import logging
    
    
    logger = logging.getLogger('app.location')
    logger.info('any message')
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2011-11-10
      • 1970-01-01
      • 1970-01-01
      • 2022-12-01
      • 1970-01-01
      • 1970-01-01
      • 2017-07-11
      相关资源
      最近更新 更多