Storage Transfer Service può rimanere in ascolto delle notifiche di eventi in AWS per trasferire automaticamente i dati aggiunti o aggiornati nella località di origine in un bucket Cloud Storage. Scopri di più sui vantaggi dei trasferimenti basati su eventi.
I trasferimenti basati su eventi rimangono in ascolto delle notifiche di eventi Amazon S3 inviate ad Amazon SQS per sapere quando gli oggetti nel bucket di origine sono stati modificati o aggiunti. Le eliminazioni di oggetti non vengono rilevate; l'eliminazione di un oggetto nell'origine non elimina l'oggetto associato nel bucket di destinazione.
I trasferimenti basati su eventi utilizzano sempre un bucket Cloud Storage come destinazione.
Prima di iniziare
Segui le istruzioni per concedere le autorizzazioni richieste sul bucket Cloud Storage di destinazione:
Crea una coda SQS
Nella console AWS, vai alla pagina Simple Queue Service.
Fai clic su Crea coda.
Inserisci un nome per questa coda.
Nella sezione Criterio di accesso, seleziona Avanzate. Viene visualizzato un oggetto JSON.
Regioni AWS standard
{ "Version": "2008-10-17", "Id": "\_\_default\_policy\_ID", "Statement": [ { "Sid": "\_\_owner\_statement", "Effect": "Allow", "Principal": { "AWS": "01234567890" }, "Action": [ "SQS:*" ], "Resource": "arn:aws:sqs:us-west-2:01234567890:test" } ] }
Regioni AWS GovCloud
{ "Version": "2008-10-17", "Id": "\_\_default\_policy\_ID", "Statement": [ { "Sid": "\_\_owner\_statement", "Effect": "Allow", "Principal": { "AWS": "01234567890" }, "Action": [ "SQS:*" ], "Resource": "arn:aws-us-gov:sqs:us-gov-west-1:01234567890:test" } ] }
Copia i valori di
AWSeResource. Questi sono univoci per ogni progetto.Incolla i valori specifici di
AWSeResourcedel passaggio precedente nel seguente snippet JSON:Regioni AWS standard
{ "Version": "2012-10-17", "Id": "example-ID", "Statement": [ { "Sid": "example-statement-ID", "Effect": "Allow", "Principal": { "Service": "s3.amazonaws.com" }, "Action": "SQS:SendMessage", "Resource": "RESOURCE", "Condition": { "StringEquals": { "aws:SourceAccount": "AWS" }, "ArnLike": { "aws:SourceArn": "arn:aws:s3:::S3_BUCKET_NAME" } } } ] }
Regioni AWS GovCloud
{ "Version": "2012-10-17", "Id": "example-ID", "Statement": [ { "Sid": "example-statement-ID", "Effect": "Allow", "Principal": { "Service": "s3.amazonaws.com" }, "Action": "SQS:SendMessage", "Resource": "RESOURCE", "Condition": { "StringEquals": { "aws:SourceAccount": "AWS" }, "ArnLike": { "aws:SourceArn": "arn:aws-us-gov:s3:::S3_BUCKET_NAME" } } } ] }
Sostituisci S3_BUCKET_NAME con il nome del bucket di origine S3.
Copia questo snippet JSON completato e utilizzalo per sostituire il JSON visualizzato nella sezione Criterio di accesso.
Fai clic su Crea coda.
Una volta completata l'operazione, prendi nota dell'Amazon Resource Name (ARN) della coda.
Attiva le notifiche nel bucket S3
Nella console AWS, vai alla pagina S3.
Nell'elenco Bucket, seleziona il bucket di origine.
Seleziona la scheda Proprietà.
Nella sezione Notifiche di eventi, fai clic su Crea notifica di un evento.
Specifica un nome per questo evento.
Nella sezione Tipi di eventi, seleziona Tutti gli eventi di creazione di oggetti.
Come Destinazione , seleziona Coda SQS e seleziona la coda che hai creato per questo trasferimento.
Fai clic su Salva modifiche.
Configura autorizzazioni
Segui le istruzioni riportate in Configura l'accesso a un'origine: Amazon S3 per creare un ID chiave di accesso e una chiave segreta o un ruolo di identità federata.
Quando segui le istruzioni, utilizza il seguente JSON quando ti viene chiesto di specificare un ruolo personalizzato o un criterio di attendibilità personalizzato:
Regioni AWS standard
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "sqs:DeleteMessage", "sqs:ChangeMessageVisibility", "sqs:ReceiveMessage", "s3:GetObject", "s3:ListBucket" ], "Resource": [ "arn:aws:s3:::S3_BUCKET_NAME", "arn:aws:s3:::S3_BUCKET_NAME/*", "AWS_QUEUE_ARN" ] } ] }
Una volta creato, prendi nota delle seguenti informazioni:
- Per un utente, prendi nota dell'ID della chiave di accesso e della chiave segreta.
- Per un ruolo di identità federata, prendi nota dell'Amazon Resource Name (ARN),
che ha il seguente formato:
arn:aws:iam::AWS_ACCOUNT:role/AWS_ROLE_NAME
Regioni AWS GovCloud
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Action": [ "sqs:DeleteMessage", "sqs:ChangeMessageVisibility", "sqs:ReceiveMessage", "s3:GetObject", "s3:ListBucket" ], "Resource": [ "arn:aws-us-gov:s3:::S3_BUCKET_NAME", "arn:aws-us-gov:s3:::S3_BUCKET_NAME/*", "AWS_QUEUE_ARN" ] } ] }
Una volta creato, prendi nota delle seguenti informazioni:
- Per un utente, prendi nota dell'ID della chiave di accesso e della chiave segreta.
- Per un ruolo di identità federata, prendi nota dell'Amazon Resource Name (ARN),
che ha il seguente formato:
arn:aws-us-gov:iam::AWS_ACCOUNT:role/AWS_ROLE_NAME
Creare un job di trasferimento
Puoi utilizzare l'API REST o la Google Cloud console per creare un job di trasferimento basato su eventi.
console Cloud
Vai alla pagina Crea job di trasferimento nella Google Cloud console.
Seleziona Amazon S3 come tipo di origine e Cloud Storage come destinazione.
Come Modalità di pianificazione , seleziona Basato su eventi e fai clic su Passaggio successivo.
Inserisci il nome del bucket S3. Il nome del bucket è il nome visualizzato nella console di gestione AWS. Ad esempio,
my-aws-bucket.Seleziona il metodo di autenticazione e inserisci le informazioni richieste, che hai creato e annotato nella sezione precedente.
Inserisci l'ARN della coda Amazon SQS che hai creato in precedenza. Utilizza uno dei seguenti formati:
- Per le regioni AWS standard:
arn:aws:sqs:AWS_REGION:AWS_ACCOUNT:AWS_QUEUE_NAME - Per le regioni AWS GovCloud:
arn:aws-us-gov:sqs:AWS_REGION:AWS_ACCOUNT:AWS_QUEUE_NAME
- Per le regioni AWS standard:
Facoltativamente, definisci eventuali filtri, quindi fai clic su Passaggio successivo.
Seleziona il bucket Cloud Storage di destinazione e, facoltativamente, il percorso.
Facoltativamente, inserisci un'ora di inizio e di fine per il trasferimento. Se non specifichi un'ora, il trasferimento inizierà immediatamente e continuerà fino all'interruzione manuale.
Specifica le opzioni di trasferimento. Per ulteriori informazioni, consulta la pagina Crea trasferimenti.
Fai clic su Crea.
Una volta creato, il job di trasferimento inizia l'esecuzione e un listener di eventi attende le notifiche nella coda SQS. La pagina dei dettagli del job mostra un'operazione all'ora e include i dettagli sui dati trasferiti per ogni job.
REST
Per creare un trasferimento basato su eventi utilizzando l'API REST, invia il seguente oggetto JSON all'endpoint transferJobs.create:
{ "description": "DESCRIPTION", "status": "ENABLED", "projectId": "PROJECT_ID", "transferSpec": { "awsS3DataSource": { "bucketName": "S3_BUCKET_NAME", "roleArn": "AWS_ROLE_ARN" }, "gcsDataSink": { "bucketName": "GCS_BUCKET_NAME" } }, "eventStream": { "name": "AWS_QUEUE_ARN", "eventStreamStartTime": "2022-12-02T01:00:00+00:00", "eventStreamExpirationTime": "2023-01-31T01:00:00+00:00" } }
I segnaposto nel JSON precedente utilizzano i seguenti valori:
- DESCRIPTION è una descrizione del job di trasferimento.
- PROJECT_ID è l'ID del progetto Google Cloud in cui viene creato il job di trasferimento.
- S3_BUCKET_NAME è il nome del bucket di origine Amazon S3.
- AWS_ROLE_ARN è l'ARN del ruolo di identità federata che hai
creato. Ad esempio,
arn:aws:iam::1234567891011:role/aws-role-nameper le regioni AWS standard oarn:aws-us-gov:iam::1234567891011:role/aws-role-nameper le regioni AWS GovCloud. - GCS_BUCKET_NAME è il nome del bucket di destinazione Cloud Storage.
- AWS_QUEUE_ARN è l'ARN della coda SQS. Ad esempio,
arn:aws:sqs:us-east-1:1234567891011:s3-notification-queueper le regioni AWS standard oarn:aws-us-gov:sqs:us-gov-east-1:1234567890:event-queueper le regioni AWS GovCloud.
eventStreamStartTime e eventStreamExpirationTime sono facoltativi.
Se l'ora di inizio viene omessa, il trasferimento inizia immediatamente; se l'ora di fine viene omessa, il trasferimento continua fino all'interruzione manuale.
Librerie client
Go
Per scoprire come installare e utilizzare la libreria client per Storage Transfer Service, consulta Librerie client di Storage Transfer Service. Per saperne di più, consulta la documentazione di riferimento dell'API Storage Transfer Service Go.
Per eseguire l'autenticazione in Storage Transfer Service, configura le Credenziali predefinite dell'applicazione. Per saperne di più, consulta Configura l'autenticazione per un ambiente di sviluppo locale.
Java
Per scoprire come installare e utilizzare la libreria client per Storage Transfer Service, consulta Librerie client di Storage Transfer Service. Per saperne di più, consulta la documentazione di riferimento dell' API Java di Storage Transfer Service.
Per eseguire l'autenticazione in Storage Transfer Service, configura le Credenziali predefinite dell'applicazione. Per saperne di più, consulta Configura l'autenticazione per un ambiente di sviluppo locale.
Node.js
Per scoprire come installare e utilizzare la libreria client per Storage Transfer Service, consulta Librerie client di Storage Transfer Service. Per saperne di più, consulta la documentazione di riferimento dell'API Storage Transfer Service Node.js.
Per eseguire l'autenticazione in Storage Transfer Service, configura le Credenziali predefinite dell'applicazione. Per saperne di più, consulta Configura l'autenticazione per un ambiente di sviluppo locale.
Python
Per scoprire come installare e utilizzare la libreria client per Storage Transfer Service, consulta Librerie client di Storage Transfer Service. Per saperne di più, consulta la documentazione di riferimento dell'API Storage Transfer Service Python.
Per eseguire l'autenticazione in Storage Transfer Service, configura le Credenziali predefinite dell'applicazione. Per saperne di più, consulta Configura l'autenticazione per un ambiente di sviluppo locale.