Не могу настроить фильтры с помощью dictConfig - PullRequest
0 голосов
/ 29 января 2019

У меня проблемы с настройкой фильтров при входе в систему с dictConfig.это конфигурационный словарь, который я использую

{ 'disable_existing_loggers': False,
  'filters': { 'request': { '()': <class 'applogging.filters.RequestFilter'>}},
  'formatters': { 'full': { 'format': '[%(asctime)s %(levelname)-8s %(request_id)s] %(name)s[%(filename)s:%(module)s:%(funcName)s:%(lineno)d]: %(message)s'},
                  'medium': { 'format': '[%(asctime)s %(levelname)-8s %(request_id)s] %(name)s[%(module)s:%(lineno)d]: %(message)s'},
                  'short': { 'format': '[%(levelname)-8s] [%(request_id)s] TEST :%(name)s:%(lineno)d: %(message)s'}},
  'handlers': { 'default': { 'class': 'logging.StreamHandler',
                             'formatter': 'short',
                             'level': 'DEBUG'}},
  'loggers': { '': { 'filters': ['request'],
                     'handlers': ['default'],
                     'level': 'WARNING',
                     'propagate': True},
               'billing': { 'level': 'INFO'},
               'boto': { 'level': 'WARNING'},
               'boto3': { 'level': 'WARNING'},
               'botocore': { 'level': 'WARNING'},
               'shiphero.bulkship': { 'level': 'INFO'},
               'shiphero.core.product.uploader': { 'level': 'INFO'},
               'shiphero.inventory.uploader': { 'level': 'INFO'},
               'shiphero_app.core.inventory': { 'level': 'INFO'},
               'shiphero_app.core.order': { 'level': 'INFO'},
               'shiphero_app.core.rules.allocation': { 'level': 'DEBUG'},
               'shiphero_app.modules.queue_workers': { 'level': 'INFO'},
               'shiphero_app.modules.tasks': { 'level': 'INFO'},
               'shiphero_app.services.pending_shipments': { 'level': 'DEBUG'},
               'shiphero_app.services.returns': { 'level': 'INFO'},
               'shiphero_app.services.shipment': { 'level': 'DEBUG'}},
  'version': 1}

Фильтр request добавляет record.request_id к записям журнала согласно https://docs.python.org/2/howto/logging-cookbook.html#filters-contextual

class RequestFilter(logging.Filter):
    def filter(self, record):
        if not request:
            return True

        record.url = request.url
        record.body = request.get_json()
        if 'request_id' not in g:
            g.request_id = uuid.uuid4()
        record.request_id = g.request_id
        return True

, но фильтр не 'Когда я пытаюсь что-то записать, он запускается: KeyError: 'request_id'

Если я добавлю это в корень словаря конфигурации:

  'loggers': { '': { 'filters': ['request'],
               ....
  'root': {
      'filters': ['request'],
  }

или я использую 'root': { 'filters': ['request'].... внутри'loggers', затем ошибка исчезает и фильтр запускается, но строки формата игнорируются.

Чего мне не хватает?

...