Gunicorn Django и запись информации в файл
Я пытаюсь настроить параметры ведения журнала, чтобы отправить logging.info('any message')
к файлу stdout.
это мой 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) в файл
1 ответов
ваш регистратор просто собирает мусор, как только вы его создаете. Вам нужно сохранить ссылку на него как регистратор, а затем использовать этот регистратор, например:
import logging
logger = logging.getLogger('app.location')
logger.info('any message')