AWS CloudTrail を使用したキャパシティブロック API コールのロギング
キャパシティブロックは、キャパシティブロックのユーザー、ロール、AWS サービスが実行したアクションを記録する AWS CloudTrail と連携しています。CloudTrail は、キャパシティブロックの API コールをイベントとしてキャプチャします。キャプチャされたコールには、キャパシティブロックコンソールからのコールと、キャパシティブロック API オペレーションへのコードコールが含まれています。証跡を作成する場合は、キャパシティブロックのイベントなど、Amazon S3 バケットへの CloudTrail イベントの継続的配信を有効にすることができます。証跡を設定しない場合でも、CloudTrail コンソールの [イベント履歴] で最新のイベントを表示できます。CloudTrail で収集された情報を使用して、キャパシティブロックに対するリクエスト、リクエスト元の IP アドレス、リクエスト者、リクエスト日時などの詳細を確認できます。
CloudTrail の詳細については、「AWS CloudTrail ユーザーガイド」を参照してください。
CloudTrail のキャパシティブロック情報
CloudTrail は、AWS アカウントを作成すると、その中で有効になります。キャパシティブロックでアクティビティが発生すると、そのアクティビティは [イベント履歴] で AWS のその他のサービスのイベントとともに CloudTrail イベントにレコードされます。最近のイベントは、AWS アカウント で表示、検索、ダウンロードできます。詳細については、 CloudTrail イベント履歴でのイベントの表示を参照してください。
イベント履歴のイベントなど、AWS アカウント のイベントの継続的な記録については、証跡を作成します。証跡により、CloudTrail はログファイルを Amazon S3 バケットに配信できます。デフォルトでは、コンソールで証跡を作成するときに、証跡がすべての AWS リージョン に適用されます。証跡は、AWS パーティションのすべてのリージョンからのイベントをログに記録し、指定した Amazon S3 バケットにログファイルを配信します。さらに、CloudTrail ログで収集したイベントデータをより詳細に分析し、それに基づいて対応するため、他の AWS サービスを構成できます。詳細については、次を参照してください:
すべてのキャパシティブロックアクションは CloudTrail によってログ記録され、Amazon EC2 API リファレンスに記録されます。例えば、CapacityBlockScheduled
と CapacityBlockActive
の各アクションを呼び出すと、CloudTrail ログファイルにエントリが生成されます。
各イベントまたはログエントリには、誰がリクエストを生成したかという情報が含まれます。アイデンティティ情報は、以下を判別するのに役立ちます:
-
リクエストが、ルート認証情報と AWS Identity and Access Management (IAM) ユーザー認証情報のどちらを使用して送信されたか。
-
リクエストがロールまたはフェデレーションユーザーのテンポラリなセキュリティ認証情報を使用して行われたかどうか。
-
リクエストが別の AWS サービスによって行われたかどうか。
詳細については、「CloudTrail userIdentity エレメント」を参照してください。
キャパシティブロックのログファイルエントリについて
「トレイル」は、指定した Amazon S3 バケットにイベントをログファイルとして配信するように設定できます。CloudTrail のログファイルは、単一か複数のログエントリを含みます。イベントは任意ソースからの単一リクエストを表し、リクエストされたアクション、アクションの日時、リクエストパラメータなどの情報を含みます。CloudTrail ログファイルは、パブリック API 呼び出しの順序付けられたスタックトレースではないため、特定の順序では表示されません。
以下は、次の CloudTrail ログエントリの例です。
注記
こちらの例では、データのプライバシーを保護するため一部のフィールドが削除されています。
TerminateCapacityBlocksInstances
{ "eventVersion": "1.05", "userIdentity": { "accountId": "123456789012", "invokedBy": "AWS Internal;" }, "eventTime": "2023-10-02T00:06:08Z", "eventSource": "ec2.amazonaws.com", "eventName": "TerminateCapacityBlockInstances", "awsRegion": "us-east-1", "sourceIPAddress": "
203.0.113.25
", "userAgent": "aws-cli/1.15.61 Python/2.7.10 Darwin/16.7.0 botocore/1.10.60", "requestParameters": null, "responseElements": null, "eventID": "a1b2c3d4-EXAMPLE", "readOnly": false, "resources": [ { "accountId": "123456789012", "type": "AWS::EC2::Instance", "ARN": "arn:aws:ec2:US East (N. Virginia):123456789012:instance/i-1234567890abcdef0" } { "accountId": "123456789012", "type": "AWS::EC2::Instance", "ARN": "arn:aws::ec2:US East (N. Virginia):123456789012:instance/i-0598c7d356eba48d7" } ], "eventType": "AwsServiceEvent", "recipientAccountId": "123456789012", "serviceEventDetails": { "capacityReservationId": "cr-12345678", } }
CapacityBlockPaymentFailed
{ "eventVersion": "1.05", "userIdentity": { "accountId": "123456789012", "invokedBy": "AWS Internal;" }, "eventTime": "2023-10-02T00:06:08Z", "eventSource": "ec2.amazonaws.com", "eventName": "CapacityBlockPaymentFailed", "awsRegion": "us-east-1", "sourceIPAddress": "
203.0.113.25
", "userAgent": "aws-cli/1.15.61 Python/2.7.10 Darwin/16.7.0 botocore/1.10.60", "requestParameters": null, "responseElements": null, "eventID": "a1b2c3d4-EXAMPLE", "readOnly": false, "resources": [ { "ARN": "arn:aws:ec2:US East (N. Virginia):123456789012:capacity-reservation/cr-12345678", "accountId": "123456789012", "type": "AWS::EC2::CapacityReservation" } ], "eventType": "AwsServiceEvent", "recipientAccountId": "123456789012", "serviceEventDetails": { "capacityReservationId": "cr-12345678", "capacityReservationState": "payment-failed" } }
CapacityBlockScheduled
{ "eventVersion": "1.05", "userIdentity": { "accountId": "123456789012", "invokedBy": "AWS Internal;" }, "eventTime": "2023-10-02T00:06:08Z", "eventSource": "ec2.amazonaws.com", "eventName": "CapacityBlockScheduled", "awsRegion": "us-east-1", "sourceIPAddress": "
203.0.113.25
", "userAgent": "aws-cli/1.15.61 Python/2.7.10 Darwin/16.7.0 botocore/1.10.60", "requestParameters": null, "responseElements": null, "eventID": "a1b2c3d4-EXAMPLE", "readOnly": false, "resources": [ { "ARN": "arn:aws:ec2:US East (N. Virginia):123456789012:capacity-reservation/cr-12345678", "accountId": "123456789012", "type": "AWS::EC2::CapacityReservation" } ], "eventType": "AwsServiceEvent", "recipientAccountId": "123456789012", "serviceEventDetails": { "capacityReservationId": "cr-12345678", "capacityReservationState": "scheduled" } }
CapacityBlockActive
{ "eventVersion": "1.05", "userIdentity": { "accountId": "123456789012", "invokedBy": "AWS Internal;" }, "eventTime": "2023-10-02T00:06:08Z", "eventSource": "ec2.amazonaws.com", "eventName": "CapacityBlockActive", "awsRegion": "us-east-1", "sourceIPAddress": "
203.0.113.25
", "userAgent": "aws-cli/1.15.61 Python/2.7.10 Darwin/16.7.0 botocore/1.10.60", "requestParameters": null, "responseElements": null, "eventID": "a1b2c3d4-EXAMPLE", "readOnly": false, "resources": [ { "ARN": "arn:aws:ec2:US East (N. Virginia):123456789012:capacity-reservation/cr-12345678", "accountId": "123456789012", "type": "AWS::EC2::CapacityReservation" } ], "eventType": "AwsServiceEvent", "recipientAccountId": "123456789012", "serviceEventDetails": { "capacityReservationId": "cr-12345678", "capacityReservationState": "active" } }
CapacityBlockFailed
{ "eventVersion": "1.05", "userIdentity": { "accountId": "123456789012", "invokedBy": "AWS Internal;" }, "eventTime": "2023-10-02T00:06:08Z", "eventSource": "ec2.amazonaws.com", "eventName": "CapacityBlockFailed", "awsRegion": "us-east-1", "sourceIPAddress": "
203.0.113.25
", "userAgent": "aws-cli/1.15.61 Python/2.7.10 Darwin/16.7.0 botocore/1.10.60", "requestParameters": null, "responseElements": null, "eventID": "a1b2c3d4-EXAMPLE", "readOnly": false, "resources": [ { "ARN": "arn:aws:ec2:US East (N. Virginia):123456789012:capacity-reservation/cr-12345678", "accountId": "123456789012", "type": "AWS::EC2::CapacityReservation" } ], "eventType": "AwsServiceEvent", "recipientAccountId": "123456789012", "serviceEventDetails": { "capacityReservationId": "cr-12345678", "capacityReservationState": "failed" } }
CapacityBlockExpired
{ "eventVersion": "1.05", "userIdentity": { "accountId": "123456789012", "invokedBy": "AWS Internal;" }, "eventTime": "2023-10-02T00:06:08Z", "eventSource": "ec2.amazonaws.com", "eventName": "CapacityBlockExpired", "awsRegion": "us-east-1", "sourceIPAddress": "
203.0.113.25
", "userAgent": "aws-cli/1.15.61 Python/2.7.10 Darwin/16.7.0 botocore/1.10.60", "requestParameters": null, "responseElements": null, "eventID": "a1b2c3d4-EXAMPLE", "readOnly": false, "resources": [ { "ARN": "arn:aws:ec2:US East (N. Virginia):123456789012:capacity-reservation/cr-12345678", "accountId": "123456789012", "type": "AWS::EC2::CapacityReservation" } ], "eventType": "AwsServiceEvent", "recipientAccountId": "123456789012", "serviceEventDetails": { "capacityReservationId": "cr-12345678", "capacityReservationState": "expired" } }