Skip to content

Commit

Permalink
Merge pull request #448 from hellohaptik/cj_setup_logging_with_django
Browse files Browse the repository at this point in the history
fix(logging): set up loggers using django's  `settings.LOGGING` to be able to log request tracebacks
  • Loading branch information
chiragjn authored Nov 10, 2021
2 parents 56f58e0 + 390d911 commit 7421047
Show file tree
Hide file tree
Showing 2 changed files with 65 additions and 24 deletions.
26 changes: 2 additions & 24 deletions chatbot_ner/config.py
Original file line number Diff line number Diff line change
@@ -1,34 +1,12 @@
from __future__ import absolute_import

import logging.handlers
import logging
import os

from elasticsearch import RequestsHttpConnection
from requests_aws4auth import AWS4Auth

BASE_DIR = os.path.dirname(os.path.dirname(__file__))
LOG_PATH = os.path.join(BASE_DIR, 'logs')

# TODO: Set this up via Django LOGGING
LOG_LEVEL = os.environ.get('DJANGO_LOG_LEVEL', 'error').upper()

# Common formatter
formatter = logging.Formatter("%(asctime)s %(levelname)s %(message)s %(module)s:%(lineno)d")

# Handler for Docker stdout
handler_stdout = logging.StreamHandler()
handler_stdout.setLevel(LOG_LEVEL)
handler_stdout.setFormatter(formatter)

# SETUP NER LOGGING
NER_LOG_FILENAME = os.path.join(LOG_PATH, 'ner_log.log')
handler = logging.handlers.WatchedFileHandler(NER_LOG_FILENAME)
handler.setFormatter(formatter)

ner_logger = logging.getLogger('NERLogger')
ner_logger.setLevel(LOG_LEVEL)
ner_logger.addHandler(handler)
ner_logger.addHandler(handler_stdout)
ner_logger = logging.getLogger('chatbot_ner')

ENGINE = os.environ.get('ENGINE')
# ES settings (Mandatory to use Text type entities)
Expand Down
63 changes: 63 additions & 0 deletions chatbot_ner/settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,69 @@
},
]

DJANGO_LOG_LEVEL = os.environ.get('DJANGO_LOG_LEVEL', 'warning').upper()
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'filters': {
'require_debug_false': {
'()': 'django.utils.log.RequireDebugFalse'
}
},
'formatters': {
'default': {
'format': '%(asctime)s %(levelname)s %(message)s %(module)s:%(lineno)d'
},
},
'handlers': {
'stdout': {
'level': DJANGO_LOG_LEVEL,
'class': 'logging.StreamHandler',
'stream': sys.stdout,
'formatter': 'default'
},
'requests_file': {
'level': 'WARNING',
'class': 'logging.handlers.WatchedFileHandler',
'filename': os.path.join(BASE_DIR, 'logs', 'requests.log'),
'formatter': 'default'
},
'chatbot_ner_file': {
'level': DJANGO_LOG_LEVEL,
'class': 'logging.handlers.WatchedFileHandler',
'filename': os.path.join(BASE_DIR, 'logs', 'ner_log.log'),
'formatter': 'default'
}
},
'loggers': {
'django.request': {
'handlers': ['chatbot_ner_file'], # TODO: switch to `requests_file` later
'level': DJANGO_LOG_LEVEL,
'propagate': True,
},
'django': {
'handlers': ['stdout'],
'level': DJANGO_LOG_LEVEL,
'propagate': True,
},
'chatbot_ner': {
'handlers': ['chatbot_ner_file'],
'level': DJANGO_LOG_LEVEL,
'propagate': False
},
'sentry_sdk.errors': {
'handlers': ['stdout'],
'level': 'WARNING',
'propagate': True
},
'elasticapm': {
'handlers': ['stdout'],
'level': 'WARNING',
'propagate': False
}
}
}

# setup sentry
setup_sentry()

Expand Down

0 comments on commit 7421047

Please sign in to comment.