Регистрация в Python - с помощью журналов JSON я могу добавить "дополнительное" значение в каждый отдельный журнал?

Я использую модуль регистрации Python вместе с Python-JSON-Logger, и я хотел бы добавить несколько ключей:

{
  "app_name": "myapp",
  "env": "prod"
}

Для всех моих журналов автоматически без выполнения следующих действий.

logger.info("Something happened", extra={"app_name": "myapp", "env": "prod"})

Но чтобы это работало так, как будто у меня было.:)

2 ответа

Если вы используете python-json-loggerи иметь пользовательский класс форматирования, вы можете добавить эти поля непосредственно в log_recordв add_fields()метод.

      from pythonjsonlogger import jsonlogger
from datetime import datetime
import logging
import json


logger = logging.getLogger()

logHandler = logging.StreamHandler()
class CustomJsonFormatter(jsonlogger.JsonFormatter):
    def add_fields(self, log_record, record, message_dict):
        super(CustomJsonFormatter, self).add_fields(log_record, record, message_dict)
        if not log_record.get('datetime'):
            log_record['datetime'] = datetime.utcnow().strftime('%Y-%m-%dT%H:%M:%S.%fZ')
        if log_record.get('level'):
            log_record['level'] = log_record['level'].upper()
        else:
            log_record['level'] = record.levelname
        log_record['app_name']='myapp'
        log_record['env']='prod'

formatter = CustomJsonFormatter('%(datetime)s %(level)s %(message)s')

logHandler.setFormatter(formatter)
logger.addHandler(logHandler)
logger.setLevel(logging.INFO)
logger.info("Something happened.")

Это распечатывает:

      {
 "datetime": "2021-12-28T23:43:25.503081Z", 
 "level": "INFO", 
 "message": "Something happened.", 
 "app_name": "myapp", 
 "env": "prod"
}

Я бы просто обернул основной класс ведения журнала нужной мне логикой следующим образом:

import logging

class CustomLogger(object):
    def __init__(self, logger_name, log_format, extra=None):
        logging.basicConfig(format=log_format)
        self.logger = logging.getLogger(logger_name)
        self.extra = extra

    def debug(self, msg, *args, **kwargs):
        self.logger.debug(msg, *args, extra=self.extra, **kwargs)

    def info(self, msg, *args, **kwargs):
        self.logger.info(msg, *args, extra=self.extra, **kwargs)

    def warning(self, msg, *args, **kwargs):
        self.logger.warning(msg, *args, extra=self.extra, **kwargs)

    def error(self, msg, *args, **kwargs):
        self.logger.error(msg, *args, extra=self.extra, **kwargs)

Тогда везде, где вам нужен регистратор, создайте его из этого класса:

from custom_logging import CustomLogger

logger_name = 'my_logger'       
log_format = '%(asctime)-15s %(app_name)-8s %(env)-8s %(message)s'
extras = {"app_name": "myapp", "env": "prod"}

logger = CustomLogger(logger_name, log_format, extras)
logger.info('Testing it out')

Надеюсь это поможет!

Другие вопросы по тегам