7

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には記録されません。メッセージだけprint >> sys.stderrが $LOGFILE に表示されるようです

情報メッセージを (stdout 経由で) ファイルに記録するにはどうすればよいですか?

4

1 に答える 1

4

あなたのロガーは、作成するとすぐにガベージコレクションを取得しています。それへの参照をロガーとして保持し、そのロガーを次のように使用する必要があります。

import logging


logger = logging.getLogger('app.location')
logger.info('any message')
于 2013-11-15T16:58:39.323 に答える