Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.
Filtraggio degli eventi relativi ai dati utilizzando selettori di eventi avanzati
Questa sezione descrive come utilizzare selettori di eventi avanzati per creare selettori dettagliati per la registrazione degli eventi relativi ai dati, che possono aiutarti a controllare i costi registrando solo gli eventi di dati specifici di interesse.
Per esempio:
-
È possibile includere o escludere chiamate API specifiche aggiungendo un filtro sul campo.
eventName
-
Puoi includere o escludere la registrazione per risorse specifiche aggiungendo un filtro sul
resources.ARN
campo. Ad esempio, se stavi registrando gli eventi relativi ai dati S3, potresti escludere la registrazione per il bucket S3 del tuo percorso. -
Puoi scegliere di registrare solo gli eventi di sola scrittura o gli eventi di sola lettura aggiungendo un filtro sul campo.
readOnly
La tabella seguente descrive i campi supportati per il filtraggio degli eventi relativi ai dati. Per un elenco dei campi supportati per ogni tipo di CloudTrail evento, consulta AdvancedEventSelectorl'AWS CloudTrail API Reference.
Campo | Richiesto | Operatori validi | Descrizione |
---|---|---|---|
|
Sì |
|
Questo campo è impostato per registrare |
|
Sì |
|
Questo campo viene utilizzato per selezionare il tipo di risorsa per cui si desidera registrare gli eventi relativi ai dati. La tabella Data events mostra i valori possibili. |
|
No |
|
Questo è un campo opzionale utilizzato per includere o escludere eventi relativi ai dati in base al |
|
No |
|
Si tratta di un campo opzionale utilizzato per filtrare o filtrare qualsiasi evento relativo ai dati registrato, ad esempio o. CloudTrail Se utilizzi il AWS CLI, puoi specificare più valori separando ogni valore con una virgola. Se utilizzi la console, puoi specificare più valori creando una condizione per ognuno dei quali |
|
No |
|
Questo è un campo facoltativo utilizzato per escludere o includere eventi di dati per una risorsa specifica fornendo il Se utilizzi il AWS CLI, puoi specificare più valori separando ogni valore con una virgola. Se utilizzi la console, puoi specificare più valori creando una condizione per ognuno dei quali |
|
No |
|
Puoi usarla per includere o escludere fonti di eventi specifiche. In genere |
|
No |
|
L'EventType da includere o escludere. Ad esempio, è possibile impostare questo campo su per |
|
No |
|
Includi o escludi eventi provenienti da una AWS Management Console sessione. Questo campo può essere impostato su |
|
No |
|
Includi o escludi eventi per le azioni intraprese da identità IAM specifiche. Per ulteriori informazioni, consulta Elemento userIdentity di CloudTrail . |
Per registrare gli eventi relativi ai dati utilizzando la CloudTrail console, scegli l'opzione Data events e quindi seleziona il tipo di risorsa che ti interessa quando crei o aggiorni un trail o un data store di eventi. La tabella Data events mostra i possibili tipi di risorse che puoi scegliere sulla CloudTrail console.

Per registrare gli eventi relativi ai dati con AWS CLI, configura il --advanced-event-selector
parametro in modo che imposti eventCategory
un resources.type
valore uguale Data
e uguale al valore del tipo di risorsa per il quale desideri registrare gli eventi relativi ai dati. La tabella Data events elenca i tipi di risorse disponibili.
Ad esempio, se desideri registrare gli eventi relativi ai dati per tutti i pool di identità di Cognito, devi configurare il --advanced-event-selectors
parametro in questo modo:
--advanced-event-selectors '[ { "Name": "Log Cognito data events on Identity pools", "FieldSelectors": [ { "Field": "eventCategory", "Equals": ["Data"] }, { "Field": "resources.type", "Equals": ["AWS::Cognito::IdentityPool"] } ] } ]'
L'esempio precedente registra tutti gli eventi relativi ai dati di Cognito nei pool di identità. È possibile perfezionare ulteriormente i selettori di eventi avanzati per filtrare in base ai resources.ARN
campi eventName
readOnly
, e per registrare eventi specifici di interesse o escludere eventi che non sono di interesse.
Puoi configurare selettori di eventi avanzati per filtrare gli eventi di dati in base a più campi. Ad esempio, puoi configurare selettori di eventi avanzati per registrare tutte le chiamate Amazon PutObject
S3 DeleteObject
e API, ma escludere la registrazione degli eventi per uno specifico bucket S3, come mostrato nell'esempio seguente. Sostituisci amzn-s3-demo-bucket
con il nome del tuo 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
/"] } ] } ]'
Puoi anche includere più condizioni per un campo. Per informazioni su come vengono valutate più condizioni, vedereCome CloudTrail valuta più condizioni per un campo.
È possibile utilizzare selettori di eventi avanzati per registrare sia gli eventi di gestione che quelli relativi ai dati. Per registrare gli eventi relativi ai dati per più tipi di risorse, aggiungi un'istruzione di selezione dei campi per ogni tipo di risorsa per cui desideri registrare gli eventi relativi ai dati.
Nota
I trail possono utilizzare selettori di eventi di base o selettori di eventi avanzati, ma non entrambi. Se si applicano selettori di eventi avanzati a un percorso, tutti i selettori di eventi di base esistenti vengono sovrascritti.
I selettori non supportano l'uso di caratteri jolly come. *
Per abbinare più valori a una singola condizione, puoi usareStartsWith
, EndsWith
NotStartsWith
, o NotEndsWith
far corrispondere esplicitamente l'inizio o la fine del campo dell'evento.
Argomenti
Come CloudTrail valuta più condizioni per un campo
Per i selettori di eventi avanzati, CloudTrail valuta più condizioni per un campo nel modo seguente:
-
Gli operatori DESELECT vengono uniti in modalità AND. Se una qualsiasi delle condizioni dell'operatore DESELECT è soddisfatta, l'evento non viene consegnato. Questi sono gli operatori DESELECT validi per i selettori di eventi avanzati:
-
NotEndsWith
-
NotEquals
-
NotStartsWith
-
-
Gli operatori SELECT vengono combinati in OR. Questi sono gli operatori SELECT validi per i selettori di eventi avanzati:
-
EndsWith
-
Equals
-
StartsWith
-
-
Le combinazioni degli operatori SELECT e DESELECT seguono le regole precedenti ed entrambi i gruppi vengono combinati in AND.
Esempio che mostra più condizioni per il campo resources.ARN
L'istruzione di selezione degli eventi di esempio seguente raccoglie gli eventi di dati per il tipo di AWS::S3::Object
risorsa e applica più condizioni sul resources.ARN
campo.
{ "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" ] } ] }
Nell'esempio precedente, gli eventi relativi ai dati di Amazon S3 per AWS::S3::Object
la risorsa verranno consegnati se:
-
Nessuna di queste condizioni dell'operatore DESELECT è soddisfatta:
-
il
resources.ARN
campoNotStartsWith
il valorearn:aws:s3:::amzn-s3-demo-bucket/deselect
-
il
resources.ARN
campoNotEndsWith
il valoreobject5
-
il
resources.ARN
campoNotEquals
il valorearn:aws:s3:::amzn-s3-demo-bucket/object6
-
-
È soddisfatta almeno una di queste condizioni dell'operatore SELECT:
-
il
resources.ARN
campoEquals
il valorearn:aws:s3:::amzn-s3-demo-bucket/object1
-
il
resources.ARN
campoStartsWith
il valorearn:aws:s3:::amzn-s3-demo-bucket/
-
il
resources.ARN
campoEndsWith
il valoreobject3
-
In base alla logica di valutazione:
-
Gli eventi di dati per
amzn-s3-demo-bucket/object1
verranno consegnati perché corrispondono al valore per l'Equals
operatore e non corrispondono a nessuno dei valori per gliNotEquals
operatoriNotStartsWith
NotEndsWith
, e. -
L'evento di dati per
amzn-s3-demo-bucket/object2
verrà fornito perché corrisponde al valore per l'StartsWith
operatore e non corrisponde a nessuno dei valori per gliNotEquals
operatoriNotStartsWith
NotEndsWith
, e. -
Gli eventi di dati per
amzn-s3-demo-bucket1/object3
verranno consegnati perché corrispondono all'EndsWith
operatore e non corrispondono a nessuno dei valori per gliNotEquals
operatoriNotStartsWith
NotEndsWith
, e. -
Gli eventi relativi ai dati di non
arn:aws:s3:::amzn-s3-demo-bucket/deselectObject4
verranno consegnati perché corrispondono alla condizione di,NotStartsWith
anche se corrispondono alla condizione dell'StartsWith
operatore. -
Gli eventi relativi ai dati di non
arn:aws:s3:::amzn-s3-demo-bucket/object5
verranno consegnati perché corrispondono alla condizione di,NotEndsWith
anche se corrispondono alla condizione dell'StartsWith
operatore. -
Gli eventi relativi ai dati non
arn:aws:s3:::amzn-s3-demo-bucket/object6
verranno consegnati perché corrispondono alla condizione dell'NotEquals
operatore anche se corrisponde alla condizione dell'StartsWith
operatore.
AWS CLI esempi per filtrare gli eventi relativi ai dati
Questa sezione fornisce AWS CLI esempi che mostrano come filtrare gli eventi relativi ai dati su campi diversi. Per ulteriori AWS CLI esempi, vedere Registra gli eventi relativi ai dati per i percorsi utilizzando selettori di eventi avanzati eRegistrazione degli eventi relativi ai dati per gli archivi dati degli eventi con AWS CLI.
Per informazioni su come registrare gli eventi relativi ai dati utilizzando la console, vedereRegistrazione degli eventi relativi ai dati con AWS Management Console.
Esempi:
Esempio 1: filtraggio sul campo eventName
Nel primo esempio, i --advanced-event-selectors
for a trail sono configurati per registrare solo le chiamate GetObject
PutObject
, e DeleteObject
API per gli oggetti Amazon S3 in bucket generici.
aws cloudtrail put-event-selectors \ --trail-name
trailName
\ --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"] } ] } ]'
Il prossimo esempio crea un nuovo archivio dati di eventi che registra gli eventi di dati per EBS Direct APIs ma esclude le chiamate API. ListChangedBlocks
È possibile utilizzare il update-event-data-storecomando per aggiornare un archivio dati di eventi esistente.
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"] } ] } ]'
Esempio 2: filtraggio sui campi resources.ARN
and userIdentity.arn
L'esempio seguente mostra come includere tutti gli eventi relativi ai dati per tutti gli oggetti Amazon S3 in uno specifico bucket S3 generico ma escludere gli eventi generati da. bucket-scanner-role
userIdentity
Il valore per gli eventi S3 per il campo resources.type
è AWS::S3::Object
. Poiché i valori ARN per gli oggetti S3 e i bucket S3 sono leggermente diversi, è necessario aggiungere l'operatore per. StartsWith
resources.ARN
aws cloudtrail put-event-selectors \ --trail-name
trailName
\ --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"]} ] } ]'