我已经在我的Django应用程序中添加了日志(log)消息,并且它成功地将日志(log)消息记录到日志(log)文件中.

现在,我try 将日志(log)消息添加到AWS CloudWatch.当我运行应用程序时,它在AWS CloudWatch中创建了log group个,但没有创建log stream个,也没有上传日志(log)消息.

我还在AWS CloudWatch中手动创建了log stream条,但仍未上传日志(log)消息.

我的Django应用程序中有以下日志(log)配置.

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台游戏机.

enter image description here

推荐答案

问题出在API中调用logger.

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文件中的日志(log)消息.

Django相关问答推荐

当RST =True时RST CSS

Django 5.0.2:TypeError:获取切片后无法过滤查询

Htmx如何从事件中访问数据?

在 Trunc 的 kind 属性中使用字段

如何根据状态计算表中数据的数量?

DecimalField 验证错误,返回不正确的值 Django

在 django/python 上访问请求标头

如何测试某个日志(log)消息是否记录在 Django 测试用例中?

在 Django 网站上找不到页面 404?

在 django 中的查询集上运行 explain的简单方法

django post_save 更新信号

现在如何在 Django 中处理每个对象的权限?

javascript 文件中的 Django {% static 'path' %}

模型表格Save保存,Get获取保存的对象

如何获取经过身份验证的用户列表?

Django Rest Framework 序列化程序中的循环依赖

找不到 msguniq.确保您安装了 GNU gettext 工具 0.15 或更新版本. (Django 1.8 和 OSX ElCapitan)

django-getlist()

Django - TypeError - save() 得到了一个意外的关键字参数force_insert

Django:如何从模板中识别调用视图?