Как изменить каталог Sanic Log по умолчанию на пользовательский каталог?

Sanic в настоящее время поддерживает каталог журналов Linux как /dev/log, и журнал не будет работать, если каталог не существует. Как мне изменить каталог на пользовательский?

2 ответа

Решение

Изучив документацию и попробовав различные комбинации, я обнаружил, что работает следующее решение, использую следующую команду dict и изменить значение пути к файлу всегда было необходимо.

from sanic.log import DefaultFilter
import sys
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'filters': {
    'accessFilter': {
        '()': DefaultFilter,
        'param': [0, 10, 20]
    },
    'errorFilter': {
        '()': DefaultFilter,
        'param': [30, 40, 50]
    }
},
'formatters': {
    'simple': {
        'format': '%(asctime)s - (%(name)s)[%(levelname)s]: %(message)s',
        'datefmt': '%Y-%m-%d %H:%M:%S'
    },
    'access': {
        'format': '%(asctime)s - (%(name)s)[%(levelname)s][%(host)s]: ' +
                  '%(request)s %(message)s %(status)d %(byte)d',
        'datefmt': '%Y-%m-%d %H:%M:%S'
    }
},
'handlers': {
    'internalFile': {
        'class': 'logging.FileHandler',
        'filters': ['accessFilter'],
        'formatter': 'simple',
        'filename': "temp/clickinternal.log"
    },
    'accessFile': {
        'class': 'logging.FileHandler',
        'filters': ['accessFilter'],
        'formatter': 'access',
        'filename': "temp/clickaccess.log"
    },
    'errorFile': {
        'class': 'logging.FileHandler',
        'filters': ['errorFilter'],
        'formatter': 'simple',
        'filename': "temp/clickerr.log"
    },
    'internal': {
        'class': 'logging.StreamHandler',
        'filters': ['accessFilter'],
        'formatter': 'simple',
        'stream': sys.stderr
    },
    'accessStream': {
        'class': 'logging.StreamHandler',
        'filters': ['accessFilter'],
        'formatter': 'access',
        'stream': sys.stderr
    },
    'errorStream': {
        'class': 'logging.StreamHandler',
        'filters': ['errorFilter'],
        'formatter': 'simple',
        'stream': sys.stderr
    }
},
'loggers': {
    'sanic': {
        'level': 'DEBUG',
        'handlers': ['internal','errorStream','internalFile', 'errorFile']
    },
    'network': {
        'level': 'DEBUG',
        'handlers': ['accessStream','errorStream','accessFile', 'errorFile']
    }
}
}



app.run(debug=True,log_config=LOGGING, host='0.0.0.0', port='8001')

Sanic использует обычную стандартную библиотекуlogging полезность.

Согласно документации:

Чтобы использовать свою собственную конфигурацию регистрации, просто используйте logging.config.dictConfigили передать log_config когда вы инициализируете Sanic приложение.

app = Sanic('test', log_config=LOGGING_CONFIG)

# or

logging.config.dictConfig(LOGGING_CONFIG)

Вот хороший ресурс по входу в Python.

То, что вы ищете, это filename ключевое слово.

LOGGING_CONFIG = {
    ...
    'filename': '/path/to/my/log'
    ...
}
Другие вопросы по тегам