Сообщения журнала из приложения Django не загружаются в AWS CloudWatch
Я добавил сообщения журнала в мое приложение Django, и оно успешно регистрирует сообщения журнала в файл журнала.
Теперь я попытался добавить сообщения журнала в AWS CloudWatch. Когда я запускаю приложение, оно создает log group
в AWS CloudWatch, но log stream
не создается, и сообщения журнала также не загружаются.
Я также вручную создал log stream
в AWS CloudWatch, но сообщения журнала все равно не были загружены.
У меня следующая конфигурация протоколирования в моем приложении Django.
logger_boto3_client = boto3.client(
"logs",
aws_access_key_id=CLOUDWATCH_AWS_ID,
aws_secret_access_key=CLOUDWATCH_AWS_KEY,
region_name=AWS_DEFAULT_REGION,
)
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'simple': {
'format': "[cid: %(cid)s] [%(asctime)s.%(msecs)03d] %(levelname)s [%(name)s:%(lineno)s] [%(funcName)s] %(message)s",
'datefmt': '%Y-%m-%d %H:%M:%S',
},
},
'handlers': {
'logger': {
'level': 'DEBUG',
'class': 'logging.handlers.RotatingFileHandler',
'filename': str(BASE_DIR) + '/logs/test.log',
'formatter': 'simple',
'filters': ['correlation'],
},
'watchtower': {
"level": "DEBUG",
"class": "watchtower.CloudWatchLogHandler",
"boto3_client": logger_boto3_client,
"log_group": "DemoLogs2",
# Different stream for each environment
"stream_name": "logs",
"formatter": "simple",
'filters': ['correlation'],
}
},
'filters': {
'correlation': {
'()': 'cid.log.CidContextFilter'
},
},
'loggers': {
'root': {
'handlers': ['logger', 'watchtower'],
'level': 'DEBUG',
'filters': ['correlation'],
'propagate': True,
}
}
}
В моем приложении я использую логгер следующим образом,
import logging
logger = logging.getLogger(__name__)
logger.info("log message.")
Моя aws cloudwatch
консоль.
Проблема заключается в вызове logger
в API.
LOGGING = {
'version': 1,
'disable_existing_loggers': False,
'formatters': {
'default': {
'format': "[cid: %(cid)s] [%(asctime)s.%(msecs)03d] %(levelname)s [%(name)s:%(lineno)s] [%(funcName)s] %(message)s",
'datefmt': '%Y-%m-%d %H:%M:%S',
}
},
'handlers': {
'file': {
'level': 'DEBUG',
'class': 'logging.handlers.RotatingFileHandler',
'filename': str(BASE_DIR) + '/logs/test.log',
'formatter': 'default',
'filters': ['correlation'],
}
'cloudwatch': {
"level": "DEBUG",
"class": "watchtower.CloudWatchLogHandler",
"boto3_client": logger_boto3_client,
"log_group": CLOUDWATCH_LOG_GROUP,
"stream_name": f"{ENV}-{CLOUDWATCH_DEFAULT_LOG_STREAM_NAME}",
"formatter": "default",
'filters': ['correlation'],
}
},
'filters': {
'correlation': {
'()': 'cid.log.CidContextFilter'
},
},
'loggers': {
# previously named as 'root'
'default': {
'level': 'DEBUG',
'handlers': ['file', 'cloudwatch'],
'filters': ['correlation'],
'propagate': False,
},
}
}
В API,
import logging
# logger = logging.getLogger(__name__)
logger = logging.getLogger("default")
logger.info("log message.")
Ранее я передавал __name__
в метод getLogger
. Теперь я передал имя регистратора default
в метод getLogger
, и теперь я могу видеть сообщения журнала как в файле log
, так и в файле cloudwatch
.