Amazon CloudWatch Logs
用户指南
AWS 服务或AWS文档中描述的功能,可能因地区/位置而异。点 击 Getting Started with Amazon AWS to see specific differences applicable to the China (Beijing) Region.

在 AWS CloudTrail 中记录 Amazon CloudWatch Logs API 调用

AWS CloudTrail 是一项服务,可用于捕获由您的 AWS 账户或代表您的 AWS 账户发出的 API 调用。这种信息经过收集后,写入存储在您指定的 Amazon S3 存储桶中的 CloudTrail 日志文件中。每当您使用 API、控制台或 AWS CLI 时,CloudTrail 就会记录 API 调用。通过使用由 CloudTrail 收集的信息,您可以确定发出了什么请求、发出请求的源 IP 地址、发出请求的人员以及发出请求的时间等。

要了解有关 CloudTrail 的更多信息 (包括如何对其进行配置和启用),请参阅 AWS CloudTrail User Guide中的什么是 AWS CloudTrail

CloudTrail 中的 CloudWatch Logs 信息

如果启用 CloudTrail 日志记录,则对 API 操作的调用将捕获在 CloudTrail 日志文件中。每个日志文件条目都包含有关生成请求的人员的信息。例如,如果发出请求以创建 CloudWatch Logs 日志流 (CreateLogStream),则 CloudTrail 会记录发出请求的人员或服务的用户身份。

日志条目中的用户身份信息可帮助您确定以下内容:

  • 请求是使用根用户凭证还是 IAM 用户凭证发出的

  • 请求是使用角色还是联合身份用户的临时安全凭证发出的

  • 请求是否由其他 AWS 服务发出

有关更多信息,请参阅 AWS CloudTrail User Guide 中的 CloudTrail userIdentity 元素

CloudTrail 日志文件可以在 S3 存储桶中存储任意长时间,不过您也可以定义 Amazon S3 生命周期规则以自动存档或删除日志文件。默认情况下,将使用 Amazon S3 服务器端加密 (SSE) 对日志文件进行加密。

如果您需要获得 CloudTrail 日志文件传输的通知,则可以将 CloudTrail 配置为在传输新日志文件时发布 Amazon SNS 通知。有关更多信息,请参阅 AWS CloudTrail User Guide 中的为 CloudTrail 配置 Amazon SNS 通知

您还可以将多个 AWS 区域和多个 AWS 账户中的 CloudTrail 日志文件聚合到单个 S3 存储桶中。有关更多信息,请参阅 AWS CloudTrail User Guide 中的从多个区域接收 CloudTrail 日志文件从多个账户接收 CloudTrail 日志文件

开启日志记录后,将在 CloudTrail 中为这些 CloudWatch Logs API 操作记录请求和响应元素:

  • CancelExportTask

  • CreateExportTask

  • CreateLogGroup

  • CreateLogStream

  • DeleteDestination

  • DeleteLogGroup

  • DeleteLogStream

  • DeleteMetricFilter

  • DeleteRetentionPolicy

  • DeleteSubscriptionFilter

  • PutDestination

  • PutDestinationPolicy

  • PutMetricFilter

  • PutRetentionPolicy

  • PutSubscriptionFilter

  • TestMetricFilter

将仅在 CloudTrail 中为以下 CloudWatch Logs API 操作记录请求元素:

  • DescribeDestinations

  • DescribeExportTasks

  • DescribeLogGroups

  • DescribeLogStreams

  • DescribeMetricFilters

  • DescribeSubscriptionFilters

不支持 GetLogEventsPutLogEventsFilterLogEvents CloudWatch Logs API 操作。

有关 CloudWatch Logs 操作的更多信息,请参阅 Amazon CloudWatch Logs API Reference

了解日志文件条目

CloudTrail 日志文件包含一个或多个日志条目。每个条目列出了多个 JSON 格式的事件。一个日志条目表示来自任何源的一个请求,包括有关所请求的操作、操作的日期和时间、请求参数等方面的信息。日志条目不是公用 API 调用的有序堆栈跟踪,因此它们不会以任何特定顺序显示。所有 API 操作的日志文件条目都类似于下面的示例。

以下日志文件条目显示某个用户调用了 CloudWatch Logs CreateExportTask 操作。

Copy
{ "eventVersion": "1.03", "userIdentity": { "type": "IAMUser", "principalId": "EX_PRINCIPAL_ID", "arn": "arn:aws:iam::123456789012:user/someuser", "accountId": "123456789012", "accessKeyId": "AKIAIOSFODNN7EXAMPLE", "userName": "someuser" }, "eventTime": "2016-02-08T06:35:14Z", "eventSource": "logs.amazonaws.com", "eventName": "CreateExportTask", "awsRegion": "us-east-1", "sourceIPAddress": "127.0.0.1", "userAgent": "aws-sdk-ruby2/2.0.0.rc4 ruby/1.9.3 x86_64-linux Seahorse/0.1.0", "requestParameters": { "destination": "yourdestination", "logGroupName": "yourloggroup", "to": 123456789012, "from": 0, "taskName": "yourtask" }, "responseElements": { "taskId": "15e5e534-9548-44ab-a221-64d9d2b27b9b" }, "requestID": "1cd74c1c-ce2e-12e6-99a9-8dbb26bd06c9", "eventID": "fd072859-bd7c-4865-9e76-8e364e89307c", "eventType": "AwsApiCall", "apiVersion": "20140328", "recipientAccountId": "123456789012" }