Die vorliegende Übersetzung wurde maschinell erstellt. Im Falle eines Konflikts oder eines Widerspruchs zwischen dieser übersetzten Fassung und der englischen Fassung (einschließlich infolge von Verzögerungen bei der Übersetzung) ist die englische Fassung maßgeblich.
Filtern von Datenereignissen mithilfe erweiterter Ereignisselektoren
In diesem Abschnitt wird beschrieben, wie Sie erweiterte Ereignisselektoren verwenden können, um detaillierte Selektoren für die Protokollierung von Datenereignissen zu erstellen. So können Sie die Kosten kontrollieren, indem Sie nur die spezifischen Datenereignisse protokollieren, die für Sie von Interesse sind.
Beispiel:
-
Sie können bestimmte API-Aufrufe ein- oder ausschließen, indem Sie dem Feld einen Filter hinzufügen.
eventName -
Sie können die Protokollierung für bestimmte Ressourcen ein- oder ausschließen, indem Sie dem
resources.ARNFeld einen Filter hinzufügen. Wenn Sie beispielsweise S3-Datenereignisse protokollieren, könnten Sie die Protokollierung für den S3-Bucket für Ihren Trail ausschließen. -
Sie können wählen, ob nur Schreibereignisse oder schreibgeschützte Ereignisse protokolliert werden sollen, indem Sie dem Feld einen Filter hinzufügen.
readOnly
In der folgenden Tabelle werden die unterstützten Felder zum Filtern von Datenereignissen beschrieben. Eine Liste der unterstützten Felder für jeden CloudTrail Ereignistyp finden Sie AdvancedEventSelectorin der AWS CloudTrail API-Referenz.
| Feld | Erforderlich | Gültige Operatoren | Beschreibung |
|---|---|---|---|
|
|
Ja |
|
Dieses Feld ist so eingestellt, dass |
|
|
Ja |
|
Dieses Feld wird verwendet, um den Ressourcentyp auszuwählen, für den Sie Datenereignisse protokollieren möchten. Die Tabelle mit Datenereignissen zeigt die möglichen Werte. |
|
|
Nein |
|
Dies ist ein optionales Feld, das verwendet wird, um Datenereignisse basierend auf dem |
|
|
Nein |
|
Dies ist ein optionales Feld, das verwendet wird, um jedes Datenereignis, bei dem protokolliert wurde, ein- oder herauszufiltern CloudTrail, z. B. Wenn Sie den verwenden AWS CLI, können Sie mehrere Werte angeben, indem Sie jeden Wert durch ein Komma trennen. Wenn Sie die Konsole verwenden, können Sie mehrere Werte angeben, indem Sie für jeden Wert, nach dem |
|
|
Nein |
|
Dies ist ein optionales Feld, das verwendet wird, um Datenereignisse für eine bestimmte Ressource auszuschließen oder einzuschließen, indem Sie die angeben Wenn Sie den verwenden AWS CLI, können Sie mehrere Werte angeben, indem Sie jeden Wert durch ein Komma trennen. Wenn Sie die Konsole verwenden, können Sie mehrere Werte angeben, indem Sie für jeden Wert, nach dem |
|
|
Nein |
|
Sie können sie verwenden, um bestimmte Ereignisquellen ein- oder auszuschließen. Das |
|
|
Nein |
|
Der EventType, der ein- oder ausgeschlossen werden soll. Sie können dieses Feld beispielsweise so einstellen, dass |
|
|
Nein |
|
Ereignisse, die aus einer AWS-Managementkonsole Sitzung stammen, einschließen oder ausschließen. Dieses Feld kann auf |
|
|
Nein |
|
Schließen Sie Ereignisse für Aktionen ein oder aus, die von bestimmten IAM-Identitäten ausgeführt werden. Weitere Informationen finden Sie unter CloudTrail -Element userIdentity. |
Um Datenereignisse mithilfe der CloudTrail Konsole zu protokollieren, wählen Sie die Option Datenereignisse und dann den gewünschten Ressourcentyp aus, wenn Sie einen Trail- oder Ereignisdatenspeicher erstellen oder aktualisieren. In der Tabelle mit Datenereignissen werden die möglichen Ressourcentypen aufgeführt, die Sie in der CloudTrail Konsole auswählen können.
Um Datenereignisse mit dem zu protokollieren AWS CLI, konfigurieren Sie den --advanced-event-selector Parameter so, dass er eventCategory gleich Data und gleich dem resources.type Wert des Ressourcentyps ist, für den Sie Datenereignisse protokollieren möchten. In der Tabelle mit Datenereignissen sind die verfügbaren Ressourcentypen aufgeführt.
Wenn Sie beispielsweise Datenereignisse für alle Cognito Identity-Pools protokollieren möchten, konfigurieren Sie den --advanced-event-selectors Parameter so, dass er wie folgt aussieht:
--advanced-event-selectors '[ { "Name": "Log Cognito data events on Identity pools", "FieldSelectors": [ { "Field": "eventCategory", "Equals": ["Data"] }, { "Field": "resources.type", "Equals": ["AWS::Cognito::IdentityPool"] } ] } ]'
Im vorherigen Beispiel werden alle Cognito-Datenereignisse in Identitätspools protokolliert. Sie können die erweiterten Ereignisauswahlen weiter verfeinern, um nach den resources.ARN FelderneventName, und zu filternreadOnly, um bestimmte Ereignisse von Interesse zu protokollieren oder Ereignisse auszuschließen, die nicht von Interesse sind.
Sie können erweiterte Ereignisauswahlen konfigurieren, um Datenereignisse auf der Grundlage mehrerer Felder zu filtern. Sie können beispielsweise erweiterte Event-Selektoren so konfigurieren, dass sie alle Amazon S3 PutObject - und DeleteObject API-Aufrufe protokollieren, aber die Ereignisprotokollierung für einen bestimmten S3-Bucket ausschließen, wie im folgenden Beispiel gezeigt. Ersetzen Sie amzn-s3-demo-bucket durch den Namen von Ihrem Bucket.
--advanced-event-selectors '[ { "Name": "Log PutObject and DeleteObject events for all but one bucket", "FieldSelectors": [ { "Field": "eventCategory", "Equals": ["Data"] }, { "Field": "resources.type", "Equals": ["AWS::S3::Object"] }, { "Field": "eventName", "Equals": ["PutObject","DeleteObject"] }, { "Field": "resources.ARN", "NotStartsWith": ["arn:aws:s3:::amzn-s3-demo-bucket/"] } ] } ]'
Sie können auch mehrere Bedingungen für ein Feld angeben. Informationen darüber, wie mehrere Bedingungen bewertet werden, finden Sie unterWie CloudTrail werden mehrere Bedingungen für ein Feld ausgewertet.
Sie können erweiterte Ereignisauswahlfunktionen verwenden, um sowohl Verwaltungs- als auch Datenereignisse zu protokollieren. Um Datenereignisse für mehrere Ressourcentypen zu protokollieren, fügen Sie für jeden Ressourcentyp, für den Sie Datenereignisse protokollieren möchten, eine Feldauswahlanweisung hinzu.
Anmerkung
Für Trails können entweder einfache oder erweiterte Event-Selektoren verwendet werden, aber nicht beide. Wenn Sie erweiterte Ereignisselektoren auf einen Trail anwenden, werden alle vorhandenen grundlegenden Ereignisselektoren überschrieben.
Selektoren unterstützen nicht die Verwendung von Platzhaltern wie. * Um mehrere Werte mit einer einzigen Bedingung abzugleichen, können SieStartsWith,, oder verwenden EndsWithNotStartsWith, NotEndsWith um explizit den Anfang oder das Ende des Ereignisfeldes abzugleichen.
Themen
Wie CloudTrail werden mehrere Bedingungen für ein Feld ausgewertet
Bei erweiterten Ereignis-Selektoren werden mehrere Bedingungen für ein Feld wie folgt CloudTrail ausgewertet:
-
DESELECT-Operatoren werden zusammen mit UND verknüpft. Wenn eine der Bedingungen für den DESELECT-Operator erfüllt ist, wird das Ereignis nicht übertragen. Dies sind die gültigen DESELECT-Operatoren für erweiterte Event-Selektoren:
-
NotEndsWith -
NotEquals -
NotStartsWith
-
-
SELECT-Operatoren stehen zusammen mit OR. Dies sind die gültigen SELECT-Operatoren für erweiterte Event-Selektoren:
-
EndsWith -
Equals -
StartsWith
-
-
Kombinationen der SELECT- und DESELECT-Operatoren folgen den obigen Regeln, und beide Gruppen werden zusammen mit UND verknüpft.
Beispiel, das mehrere Bedingungen für das resources.ARN Feld zeigt
Die folgende Beispielanweisung zur Ereignisauswahl sammelt Datenereignisse für den AWS::S3::Object Ressourcentyp und wendet mehrere Bedingungen auf das resources.ARN Feld an.
{ "Name": "S3Select", "FieldSelectors": [ { "Field": "eventCategory", "Equals": [ "Data" ] }, { "Field": "resources.type", "Equals": [ "AWS::S3::Object" ] }, { "Field": "resources.ARN", "Equals": [ "arn:aws:s3:::amzn-s3-demo-bucket/object1" ], "StartsWith": [ "arn:aws:s3:::amzn-s3-demo-bucket/" ], "EndsWith": [ "object3" ], "NotStartsWith": [ "arn:aws:s3:::amzn-s3-demo-bucket/deselect" ], "NotEndsWith": [ "object5" ], "NotEquals": [ "arn:aws:s3:::amzn-s3-demo-bucket/object6" ] } ] }
Im vorherigen Beispiel werden Amazon S3 S3-Datenereignisse für die AWS::S3::Object Ressource zugestellt, wenn:
-
Keine dieser Bedingungen für den DESELECT-Operator ist erfüllt:
-
das
resources.ARNFeld,NotStartsWithder Wertarn:aws:s3:::amzn-s3-demo-bucket/deselect -
das
resources.ARNFeldNotEndsWithder Wertobject5 -
das
resources.ARNFeldNotEqualsder Wertarn:aws:s3:::amzn-s3-demo-bucket/object6
-
-
Mindestens eine der folgenden Bedingungen für den SELECT-Operator ist erfüllt:
-
das
resources.ARNFeld,Equalsder Wertarn:aws:s3:::amzn-s3-demo-bucket/object1 -
das
resources.ARNFeldStartsWithder Wertarn:aws:s3:::amzn-s3-demo-bucket/ -
das
resources.ARNFeldEndsWithder Wertobject3
-
Basierend auf der Bewertungslogik:
-
Datenereignisse für
amzn-s3-demo-bucket/object1werden übermittelt, da sie mit dem Wert für denEqualsOperator und keinem der Werte für dieNotEqualsOperatorenNotStartsWithNotEndsWith, und übereinstimmen. -
Das Datenereignis für
amzn-s3-demo-bucket/object2wird übermittelt, da es mit dem Wert für denStartsWithOperator und keinem der Werte für dieNotEqualsOperatorenNotStartsWithNotEndsWith, und übereinstimmt. -
Das
amzn-s3-demo-bucket1/object3Datenereignis für wird übermittelt, weil es demEndsWithOperator entspricht und keinem der Werte für dieNotEqualsOperatorenNotStartsWithNotEndsWith, und. -
Datenereignisse für
arn:aws:s3:::amzn-s3-demo-bucket/deselectObject4werden nicht übermittelt, da sie der Bedingung für entsprechen,NotStartsWithobwohl sie der Bedingung für denStartsWithOperator entsprechen. -
Datenereignisse für
arn:aws:s3:::amzn-s3-demo-bucket/object5werden nicht zugestellt, da sie der Bedingung für entsprechen,NotEndsWithobwohl sie der Bedingung für denStartsWithOperator entsprechen. -
Datenereignisse für
arn:aws:s3:::amzn-s3-demo-bucket/object6werden nicht zugestellt, da sie der Bedingung für denNotEqualsOperator entsprechen, obwohl sie der Bedingung für denStartsWithOperator entsprechen.
AWS CLI Beispiele für das Filtern von Datenereignissen
Dieser Abschnitt enthält AWS CLI Beispiele, die zeigen, wie Datenereignisse in verschiedenen Feldern gefiltert werden. Weitere AWS CLI Beispiele finden Sie unter Protokollieren Sie Datenereignisse für Trails mithilfe erweiterter Event-Selektoren undProtokollieren von Datenereignissen für Ereignisdatenspeicher mit dem AWS CLI.
Hinweise zum Protokollieren von Datenereignissen mithilfe der Konsole finden Sie unterProtokollierung von Datenereignissen mit dem AWS-Managementkonsole.
Beispiele:
Beispiel 1: Nach dem eventName Feld filtern
Im ersten Beispiel sind die --advanced-event-selectors for a trail so konfiguriert, dass sie nur die DeleteObject API-Aufrufe GetObjectPutObject, und für Amazon S3 S3-Objekte in Allzweck-Buckets protokollieren.
aws cloudtrail put-event-selectors \ --trail-nametrailName\ --advanced-event-selectors '[ { "Name": "Log GetObject, PutObject and DeleteObject S3 data events", "FieldSelectors": [ { "Field": "eventCategory", "Equals": ["Data"] }, { "Field": "resources.type", "Equals": ["AWS::S3::Object"] }, { "Field": "eventName", "Equals": ["GetObject","PutObject","DeleteObject"] } ] } ]'
Im nächsten Beispiel wird ein neuer Ereignisdatenspeicher erstellt, der Datenereignisse für EBS Direct protokolliert, API-Aufrufe APIs jedoch ausschließtListChangedBlocks. Sie können den update-event-data-storeBefehl verwenden, um einen vorhandenen Ereignisdatenspeicher zu aktualisieren.
aws cloudtrail create-event-data-store \ --name "eventDataStoreName" --advanced-event-selectors '[ { "Name": "Log all EBS Direct API data events except ListChangedBlocks", "FieldSelectors": [ { "Field": "eventCategory", "Equals": ["Data"] }, { "Field": "resources.type", "Equals": ["AWS::EC2::Snapshot"] }, { "Field": "eventName", "NotEquals": ["ListChangedBlocks"] } ] } ]'
Beispiel 2: Filtern nach den userIdentity.arn Feldern resources.ARN und
Das folgende Beispiel zeigt, wie Sie alle Datenereignisse für alle Amazon S3 S3-Objekte in einen speziellen S3-Bucket für allgemeine Zwecke aufnehmen, aber Ereignisse ausschließen, die von der generiert wurden bucket-scanner-roleuserIdentity. Der Wert für S3-Ereignisse für das resources.type-Feld ist AWS::S3::Object. Da sich die ARN-Werte für S3-Objekte und S3-Buckets geringfügig unterscheiden, müssen Sie den StartsWith Operator for resources.ARN hinzufügen.
aws cloudtrail put-event-selectors \ --trail-nametrailName\ --advanced-event-selectors \ '[ { "Name": "S3EventSelector", "FieldSelectors": [ { "Field": "eventCategory", "Equals": ["Data"] }, { "Field": "resources.type", "Equals": ["AWS::S3::Object"] }, { "Field": "resources.ARN", "StartsWith": ["arn:partition:s3:::amzn-s3-demo-bucket/"] }, { "Field": "userIdentity.arn", "NotStartsWith": ["arn:aws:sts::123456789012:assumed-role/bucket-scanner-role"]} ] } ]'
Beispiel 3: Filtern nach den eventName Feldern resources.type und, um einzelne Objekte auszuschließen, die durch ein Amazon S3 DeleteObjects S3-Ereignis gelöscht wurden
Das folgende Beispiel zeigt, wie Sie alle Datenereignisse für alle Amazon S3 S3-Objekte in einen speziellen Allzweck-Amazon S3-Bucket aufnehmen, aber die einzelnen Objekte ausschließen, die durch den DeleteObject Vorgang gelöscht wurden. Der Wert für S3-Ereignisse für das resources.type-Feld ist AWS::S3::Object. Der Wert für den Namen des Ereignisses istDeleteObject.
aws cloudtrail put-event-selectors \ --trail-nametrailName\ --advanced-event-selectors \ { "Name": "Exclude Events for DeleteObject operation", "FieldSelectors": [ { "Field": "eventCategory", "Equals": [ "Data" ] }, { "Field": "resources.type", "Equals": [ "AWS::S3::Object" ] }, { "Field": "eventName", "NotEquals": [ "DeleteObject" ] } ] }, { "Name": "Exclude DeleteObject Events for individual objects deleted by DeleteObjects Operation", "FieldSelectors": [ { "Field": "eventCategory", "Equals": [ "Data" ] }, { "Field": "resources.type", "Equals": [ "AWS::S3::Object" ] }, { "Field": "eventName", "Equals": [ "DeleteObject" ] }, { "Field": "eventType", "NotEquals": [ "AwsServiceEvent" ] } ] } ] (edited)