После нескольких часов выяснения, что в итоге может быть не так с моим кодом, у меня теперь есть результат, который меня удовлетворяет. Сначала я создал файл loggingsetup.py
, в котором я настроил свои логгеры python с помощью dictConfig:
LOGGING = {
'version': 1,
'disable_existing_loggers': True,
'formatters': { # Sets up the format of the logging output
'simple': {
'format': '%(asctime)s - %(name)s - %(levelname)s - %(message)s',
'datefmt': '%y %b %d, %H:%M:%S',
},
},
'filters': {
'filterForSplunk': { # custom loggingFilter, to not have Logs logged to Splunk that have the word celery in the name
'()': 'loggingsetup.RemoveCeleryLogs', # class on top of this file
'logsToSkip': 'celery' # word that it is filtered for
},
},
'handlers': {
'splunk': { # handler for splunk, level Warning. to not have many logs sent to splunk
'level': 'WARNING',
'class': 'splunk_logging_handler.SplunkLoggingHandler',
'url': os.getenv('SPLUNK_HTTP_COLLECTOR_URL'),
'splunk_key': os.getenv('SPLUNK_TOKEN'),
'splunk_index': os.getenv('SPLUNK_INDEX'),
'formatter': 'simple',
'filters': ['filterForSplunk']
},
'console': {
'level': 'DEBUG',
'class': 'logging.StreamHandler',
'stream': 'ext://sys.stdout',
'formatter': 'simple',
},
},
'loggers': { # the logger, root is used
'': {
'handlers': ['console', 'splunk'],
'level': 'DEBUG',
'propagate': 'False', # does not give logs to other logers
}
}
}
Для фильтра журналирования мне пришлось создать класс, который наследуется от класса logging.Filter. Класс также опирается на файл loggingsetup.py
class RemoveCeleryLogs(logging.Filter): # custom class to filter for celery logs (to not send them to Splunk)
def __init__(self, logsToSkip=None):
self.logsToSkip = logsToSkip
def filter(self, record):
if self.logsToSkip == None:
allow = True
else:
allow = self.logsToSkip not in record.name
return allow
После этого вы можете настроить регистраторы следующим образом:
logging.config.dictConfig(loggingsetup.LOGGING)
logger = logging.getLogger('')
И так как сельдерей перенаправил свои журналы и журналы были удвоены, мне пришлось обновить app.conf:
app.conf.update({
'worker_hijack_root_logger': False, # so celery does not set up its loggers
'worker_redirect_stdouts': False, # so celery does not redirect its logs
})
Следующая проблема, с которой я столкнулся, заключалась в том, что моя выбранная библиотека Splunk_Logging что-то перепутала с URL. Поэтому мне пришлось создать свой собственный класс splunk_handler, который наследуется от класса logging.Handler. Важные строки здесь следующие:
auth_header = {'Authorization': 'Splunk {0}'.format(self.splunk_key)}
json_message = {"index": str(self.splunk_index), "event": data}
r = requests.post(self.url, headers=auth_header, json=json_message)
Я надеюсь, что смогу помочь с этим ответом кому-то, кто сталкивается с похожими проблемами при ведении журнала python, spunk и сельдерея! :)