使用 Amazon CloudTrail 记录 Amazon IoT OTA API 调用 - FreeRTOS
Amazon Web Services 文档中描述的 Amazon Web Services 服务或功能可能因区域而异。要查看适用于中国区域的差异,请参阅中国的 Amazon Web Services 服务入门

本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。

使用 Amazon CloudTrail 记录 Amazon IoT OTA API 调用

FreeRTOS 与 CloudTrail 集成了一项可捕获的服务Amazon IoTOTA API 将调用日志文件并传送到您指定的 Amazon S3 存储桶。 CloudTrail 捕获来自的代码对的 API 调用Amazon IoTOTA API。通过使用 CloudTrail 收集的信息,您可以确定已对发出的请求。Amazon IoTOTA、发出请求的源 IP 地址、请求方、请求时间等。

有关 CloudTrail 的更多信息,包括如何对其进行配置和启用,请参阅Amazon CloudTrail 用户指南》

CloudTrail 中的 FreeRTOS 信息

何时 CloudTrail 在您的中启用日志记录Amazon向账户、向其进行的 API 调用Amazon IoT跟踪 OTA 操作 CloudTrail 与其他人一起写入的日志文件Amazon服务记录。 CloudTrail 基于时间段和文件大小来确定何时创建新文件并向其写入内容。

以下Amazon IoTCloudTrail 将记录 OTA 控制层面的操作:

注意

Amazon IoTCloudTrail 不会记录 OTA 数据层面的操作(设备端)。使用 CloudWatch 来监控这些。

每个日志条目都包含有关生成请求的人员的信息。日志条目中的用户身份信息可帮助您确定以下内容:

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

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

  • 请求是否由其它 Amazon 服务发出。

有关更多信息,请参阅 。CloudTrail userIdentity 元素.Amazon IoT 记录了 OTA 操作记录在Amazon IoTOTA API 参考.

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

如果您希望在传输日志文件时收到通知,则可以配置 CloudTrail 以发布 Amazon SNS 通知。有关更多信息,请参阅 。为 CloudTrail 配置 Amazon SNS 通知.

你也可以聚合Amazon IoT来自多个 OTA 日志文件Amazon多个区域和多个Amazon将账户放入单个 Amazon S3 存储桶。

有关更多信息,请参阅 。接收 CloudTrail 多个区域中的日志文件接收 CloudTrail 多个账户中的日志文件.

了解 FreeRTOS 日志文件条目

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

以下示例显示了 CloudTrail 说明来自调用日志的日志的日志条目CreateOTAUpdateaction.

{ "eventVersion": "1.05", "userIdentity": { "type": "IAMUser", "principalId": "EXAMPLE", "arn": "arn:aws:iam::your_aws_account:user/your_user_id", "accountId": "your_aws_account", "accessKeyId": "your_access_key_id", "userName": "your_username", "sessionContext": { "attributes": { "mfaAuthenticated": "false", "creationDate": "2018-08-23T17:27:08Z" } }, "invokedBy": "apigateway.amazonaws.com" }, "eventTime": "2018-08-23T17:27:19Z", "eventSource": "iot.amazonaws.com", "eventName": "CreateOTAUpdate", "awsRegion": "your_aws_region", "sourceIPAddress": "apigateway.amazonaws.com", "userAgent": "apigateway.amazonaws.com", "requestParameters": { "targets": [ "arn:aws:iot:your_aws_region:your_aws_account:thing/Thing_CMH" ], "roleArn": "arn:aws:iam::your_aws_account:role/Role_FreeRTOSJob", "files": [ { "fileName": "/sys/mcuflashimg.bin", "fileSource": { "fileId": 0, "streamId": "your_stream_id" }, "codeSigning": { "awsSignerJobId": "your_signer_job_id" } } ], "targetSelection": "SNAPSHOT", "otaUpdateId": "FreeRTOSJob_CMH-23-1535045232806-92" }, "responseElements": { "otaUpdateArn": "arn:aws:iot:your_aws_region:your_aws_account:otaupdate/FreeRTOSJob_CMH-23-1535045232806-92", "otaUpdateStatus": "CREATE_PENDING", "otaUpdateId": "FreeRTOSJob_CMH-23-1535045232806-92" }, "requestID": "c9649630-a6f9-11e8-8f9c-e1cf2d0c9d8e", "eventID": "ce9bf4d9-5770-4cee-acf4-0e5649b845c0", "eventType": "AwsApiCall", "recipientAccountId": "recipient_aws_account" }